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Foreword 



This Technical Specification (TS) has been produced by ETSI 3rd Generation Partnership Project (3GPP). 

The present document may refer to technical specifications or reports using their 3GPP identities, UMTS identities or 
GSM identities. These should be interpreted as being references to the corresponding ETSI deliverables. 

The cross reference between GSM, UMTS, 3GPP and ETSI identities can be found under www.etsi.org/kev ■ 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 
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Scope 



The present document covers the minimum characteristics considered necessary in order to provide comphance to 
GSM 03.19 "SIM API for Java Card ™" [7]. 

The present document describes the technical characteristics and methods of test for testing the SIM API for Java Card 
(tm) [7] implemented in the subscriber identity modules (SIMs) for GSM. It specifies the following parts: 

- test applicabihty 

test environment description 

tests format 

test area reference 

conformance requirements 

test auite files 

test procedure 

test coverage and, 

a description of the associated testing tools that shall be used. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] (void) 

[2] (void) 

[3] GSM 11.11: "Digital cellular telecommunication system (Phase 2+); Specification of the 

Subscriber Identity Module - Mobile Equipment (SIM - ME) interface". 

[4] GSM 1 1.14: "Digital cellular telecommunications system (Phase 2+); 

Specification of the SIM application toolkit for the Subscriber Identity Module - Mobile 
Equipment (SIM - ME) interface". 

[5] GSM 11.17: "Subscriber Identity Module" (SIM) conformance test specification". 

[6] (void) 

[7] GSM 03.19 version 7.4.0: "Digital cellular telecommunications system (Phase 2+); Subscriber 

Identity Module Application Programming Interface (SIM API); SIM API for Java Card''^; 
Stage 2". 

[8] GSM 03.48 version 8.4.0: "Digital cellular telecommunications system (Phase 2+); Security 

Mechanisms for the SIM application toolkit; Stage 2" 
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[9] ISO/IEC 7816-3 (1997) " Identification cards - Integrated circuit(s) cards with contacts, Part 3: 

Electronic signals and transmission protocols" 

[10] GSM 02.19 "Digital cellular telecommunications system (Phase 2+, Release 98); Subscriber 

Identity Module Application Programming Interface (SIM API); Service description; Stage 1" 

[11] S UN J ava Card Specification " J ava Card 2 . 1 API Specification " 

[12] SUN Java Card Specification "Java Card 2.1 Runtime Environment Specification" 

[13] SUN Java Card Specification "Java Card 2.1 VM Architecture Specification" 

[14] ETSI TS 101 220 v3.0.0 "Numbering System for Telecommunication IC card applications" 

[15] GSM 11.10-1: "Digital cellular telecommunication system (Phase 2+); 

Mobile Station (MS) conformance specification; Part 1: Conformance specification". 

3 Definitions and abbreviations 

3.1 Definitions 

The definitions specified in GSM 11.10-1 [15] clause 3.3 shall apply, unless otherwise specified in the present clause. 

Applet: An Applet is an application built up using a number of classes which will run under the control of the Java 
Card virtual machine. 

Applet installation parameters: Default values for applet installation parameters. 

Applet loading script: File containing the APDU commands that will load and install the test applet in the card. 

CleanUp Script file: File containing the APDU commands that will restore the Default Initial Conditions on the SIM 

Conformance Requirement Reference: Description of the expected card behaviour according to 03.19 specification. 

Expected state: the state in which the SIM is supposed to be after the execution of the test procedure applied on the 
relevant initial conditions 

Security parameters: Minimum security requirements defined for the applet installation process. 

Test Area: Set of Test Cases applicable to a specific part ( class method, framework behaviour,...) of the 03.19 
specification. 

Test Case: Elementary test that checks for compliance with one or more Conformance Requirement References. 

Test Output file: TBD. 

Test procedure: the sequence of actions/commands to perform all the test cases defined in a test area. 

Test Script file: File containing the APDU commands that will execute and verify the test results. 

Test Toolkit Applet: Applet designed to test a specific functionality of the SIM API 03.19 specification. 

3.2 Abbreviations 

For the purpose of the present document, the following abbreviations apply, in addition to those listed in 
GSM 01.04 [2]: 

AC Application Code 

AID Application Identifier 

APDU Application Protocol Data Unit 

API Application Programming Interface 

CAD Card Acceptance Device 
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FFS 
IFD 
JCRE 

JVM 
SIM 
SE 



For Further Study 

Interface Device 

Java CardT'^ Run Time Environment 

Java Virtual Machine 

Subscriber Identity Module 

Sending Entity 



4 Test Environment 

This clause specifies requirements that shall be met and the testing rules that shall be followed during the test 
procedure. 



4.1 Applicability 



The tests defined in this specification shall be performed taking into account the services supported by the card as 
specified in the EFsst file. 

This specification contains tests that test interoperability at the API level. This specification does not currently contain 
tests for interoperability at the SIM API framework and at the byte code level. These are for further study. 

The test defined in this specification are applicable to cards implementing TS 03.19 [7] version 7.4.0 unless otherwise 
stated. 



4.2 Test environment description 

The general architecture for the test environment is: 



' Scope of the Test Suite. 
. Elements of the Test Suite 



GSM()3.19and 

Java Card™ 2.1 

export files 



Conversion 
parameters. 



Applet loading 
script 



Test 
Toolkit 
Applet 




Note: This diagram shows the test architecture required to test interoperability at both API and bytcode level. 
The latter is currently not included in the current specification. The diagram is for information. 
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4.3 Tests format 
4.3.1 Test Area Reference 

Each test area is referenced as follows: 

API Testing;: 'API_[package name]_[classname]_[methodname]' where 
package name: 

sim. access package: '1' 
sim.toolkit package: '2' 
class name: 

yyy: 3 letters for each class. 
See Annex A for full classes acronyms list, 
method name: 

zzzz[input parameters]: 

See Annex A for full methods name acronyms list. 
FWK: framework testing 

[TBD] 
LDR: loader testing 
[TBD] 

4.3.1.1 Conformance requirements 

The conformance requirements are expressed in the following way: 

Method prototype as listed in GSM 03.19 [7] specification. 

Normal execution: 

Contains normal execution and correct parameters limit values, each referenced as a Conformance 
Requirement Reference Normal (CRRN) 

Parameters error: 

Contains parameter errors and incorrect parameter limit values, each referenced as a Conformance 
Requirement Reference Parameter Error (CRRP) 

Context error: 

Contains errors due to the context the method is used in, each referenced as a Conformance Requirement 
Reference Context Error (CRRC) 

4.3.1.2 Test Area files 

The files included in the Test Area use the following naming convention: 

Test Script: [Test Area Reference]_[Test script number]. scr 

Test Applet: [Test Area Reference]_[Test applet number] .Java 

Load Script: [Test Area Reference]_[Load Script number] .Idr 
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Cleanup Script: [Test Area Reference]_[Cleanup Script number]. clr 

The test script, applet, installation parameters, load script, cleanup script and conversion parameters numbers start from 
'1'. 

The test script, load script and cleanup script shall share a common syntax and format (see Annex B). 

Scripts file shall be run in the following order: 

[Test Area Reference]_l .Idr 

[Test Area Reference]_l.scr 

[Test Area Reference]_l.clr 

[Test Area Reference]_2.1dr 

[Test Area Reference]_2.scr 

[Test Area Reference]_2.clr 



[Test Area Reference]_n.ldr 
[Test Area Reference]_n.scr 
[Test Area Reference]_n.clr 
In case that one of the files is not needed, it shall be skipped during the tests execution. 

4.3.1.3 Test Procedure 

Each test procedure contains a table to indicate the expected responses form the API and/or the APDU level as follows: 



Test Case 


Id 


Description 


API Expectation 


APDU Expectation 




Test Case detailed description 


API expected behavior. 


Expected response at APDU 
level. 



4.3.1 .4 Test Coverage 

The table at the end of each test procedure indicates the correspondence between the Conformance Requirements 
Reference (CRR) and the different test cases. 

4.4 Initial Conditions 

The Initial Conditions are a set of general prerequisites for the SIM prior to the execution of testing. For each test 
procedure described in this document, the following rules apply to the Initial Conditions: 

unless otherwise stated, the file system and the files' content shall fulfil the requirements described in the 
"Default Prepersonalisation" paragraph; 

unless otherwise stated, before installing the applet(s) relevant to the current test procedure, all packages specific 
to other test procedures shall not be present. 

When both statements apply, a test procedure is said to be in the "Default Initial Conditions" state. 

4.5 Package name 

Java packages integrating this Test Suite shall follow this naming convention: 
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sim.test.access.[Test Area Reference]: Java Card packages containing Test Area References for the GSM 03.19 
sim.access package. 

sim.test.framework.[Test Area Reference]: Java Card packages containing Test Area References for the GSM 03.19 
framework. 

sim.test.util: for the Test util package defined in this Test Suite. 

sim.test.toolkit.[Test Area Reference]: Java Card packages containing Test Area References for the GSM 03.19[7] 
sim.toolkit package. 

Example: The package ../sim.test.access.[Test Area Reference] creates the following directory structure 

../sim/test/access/[Test Area Reference]/API_l _..._[!. .n].*, where API_l_..._[l..n].'*' are the 
different test applets Java source files used in [Test Area Reference] . 



4.6 AID Coding 



The AID coding for the API Test Packages, Applet classes and Applet shall be as specified in TS 101 220 [14]. In 
addition, the following TAR values are defined for use within the present document: 

TAR Coding (3 bytes/ 24 bits): 



bl 


b2 


b3 


b4 


b5 


b6 : :b21 


b22 


b23 


b24 









































Specific Test Applet Name 



Test Package Identifier 



Test package Identifier( bits bl-b3): 

000 reserved (as TAR= '00.00.00' is reserved for Card Manager) 

001 API 

010 Framework 
Oil Loader 
111 sim.test.util 
other values are RFU 

Specific applet test name (bits b4-b24): 



b4 



b5 



b6 



b7 



b8 



b9 



blO 



bll 



bl2 



bl3 



bl4 



bl5 



hl6 



bl7 



bl8 



bl9 



b20 



b21 



b22 



b23 



b24 



Applet instance 
Number 

Applet Class Number 

Method 

Class 

API Test Package 



for API test package(3 bits) 
001 sim.access 
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010 sim. toolkit 

other are RFU 

Class (5 bits): need to be assigned specification order see Annex A for the full list 

Method (6 bits): need to be assigned specification order see Annex A for the full list 

Applet Class number (5 bits): linked to Test Area, it shall start with 1 for classes and shall be for package. 

Applet Instance number (2 bits) defined in the test procedure it shall start with 01 for applet instance and shall 
be for package and class. 

Application Provider specific data (1 byte): 

'00' for Package 

'Or for Applet class 

'02' for Applet Instance 

For example, the AID of Package sim.test.util is 'AO 00 00 00 09 00 02 FF FF FF FF 89 EO 00 00 00' 

4.7 Test Equipment 

These subclauses recommend a minimum specification for each of the items of test equipment referenced in the tests. 

4.7.1 APDUtool 

This test tool shall meet the following requirements: 

be able to send command to the card TPDU; 

be able to check none, only a part, or all of the data returned; 

be able to check none, only part, or all of the status returned; 

be able to accept all valid status codes returned; 

be able to support Reader commands; 

be able to generate a log file for each test execution. 

if more data is returned than defined in the test specification, the tool shall continue; 

if less data is returned than defined in the test specification, the tool shall aborts and return an error; 

if there is an error in data or status returned, the tool shall abort and return an error. 
The log file produced by the test tool shall include the following information: 

all commands issued; 

all data returned; 

all status returned; 

all errors codes; 

expected data and status in case of error; 

comments from the scripts; 

a log message to report success or failure of the test. 
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Annex D includes Java source code for the sim.test.util package as well as loading , testing and cleaning script 
examples. 



4.7.3 Applet installation parameters 



4.7.3.1 Security parameters 

Loading scripts shall use the following security parameters as stated in GSM 03.48 [8] for applet installation: 



Parameter 


Value in hexadecimal 


SPI 


OAOO 


KIC 


00 


KID 


11 


TAR 


00 00 00 


CNTR 


00 00 00 00 01 


PCNTR 


00 


Key 


01 23 45 67 89 AB CD EF 



4.7.3.2 



Loading components 



Cap files in loading scripts shall not include the descriptor component as described in Java Card 2.1 VM Architecture 
Specification [13]. 



4.8 Testing methodology 



4.8.1 Test interfaces and facilities 

The SIM-ME interface provides the main transport interface for the purpose of performing conformance tests. 
The SIM API interface provides the main test interface for the purpose of performing conformance tests. 



Test plan 



The test plan is divided according to the SIM API specification, that way the tests will follow the class hierarchy for the 
sim.toolkit and sim.access package; for the SIM Toolkit framework this test plan describes the different points that will 
be tested with the present test specification. 



6 API Test Plan 

6.1 Package sim.access: 
6.1.1 Interface SIMView 

Note: The Test applet shall be run on a class that implements this interface. 

6.1.1.1 Constants 

Test Area Reference: API 1 SVW CONST 
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6.1.1.1.1 Conformance Requirements 

This section does not describe the conformance requirements for a method, but rather for the constants of the interface. 

Normal execution 

CRRNl: The constants shall have the same name and value that is defined in GSM 03.19 []. 

6.1.1.1.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 
Test Script: API_l_SVW_CONST_l.scr 

Test Applet: API_l_SVW_CONST_l.java 

Load Script: API_l_SVW_CONST_l.ldr 

Cleanup Script: API_l_SVW_CONST_l.cb- 



6.1.1.1.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


01 


Check constant FID MF = '3F00' 






02 


Check constant FID DF TELECOM = 7F10' 






03 


Check constant FID DF GSM = '7F20' 






04 


Check constant FID DF DCS 1800 = '7F21' 






05 


Check constant FID DF IS 41 = 7F22' 






06 


Check constant FID DF FP CTS = '7F23' 






07 


Check constant FID DF GRAPHICS = '5F50' 






08 


Check constant FID DF IRIDIUM = '5F30' 






09 


Check constant FID DF GLOBALSTAR = '5F31' 






10 


Check constant FID DF ICO = '5F32' 






11 


Check constant FID DF ACES = '5F33' 






12 


Check constant FID DF PCS 1900 = '5F40' 






13 


Check constant FID DF CTS = '5F60' 






14 


Check constant FID DF SOLSA = '5F70' 






15 


Check constant FID EF ICCID = '2FE2' 






16 


Check constant FID EF ELP = '2F05' 






17 


Check constant FID EF ADN = '6F3A' 






18 


Check constant FID EF FDN = '6F3B' 






19 


Check constant FID EF SMS = '6F3C' 






20 


Check constant FID EF CCP = '6F3D' 






21 


Check constant FID EF MSISDN = '6F40' 






22 


Check constant FID EF SMSP = '6F42' 






23 


Check constant FID EF SMSS = '6F43' 






24 


Check constant FID EF LND = '6F44' 






25 


Check constant FID EF SDN = '6F49' 






26 


Check constant FID EF EXT1 = '6F4A' 






27 


Check constant FID EF EXT2 = '6F4B' 






28 


Check constant FID EF EXT3 = '6F4C 






29 


Check constant FID EF BDN = '6F4D' 






30 


Check constant FID EF EXT4 = '6F4E' 






31 


Check constant FID EF SMSR = '6F47' 






32 


Check constant FID EF IMG = '4F20' 






33 


Check constant FID EF LP = '6F05' 






34 


Check constant FID EF IMSI = '6F07' 






35 


Check constant FID EF KC = '6F20' 






36 


Check constant FID EF PLMNSEL = '6F30' 






37 


Check constant FID EF HPLMN = '6F31' 






38 


Check constant FID EF ACMMAX = '6F37' 






39 


Check constant FID EF SST = '6F38' 






40 


Check constant FID EF ACM = '6F39' 






41 


Check constant FID EF GID1 = '6F3E' 






42 


Check constant FID EF GID2 = '6F3F' 
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Id 


Description 


API Expectation 


APDU Expectation 


43 


Check constant FID EF SPN = '6F46' 






44 


Check constant FID EF PUCT = '6F41' 






45 


Check constant FID EF CBMI = '6F45' 






46 


Check constant FID EF BCCH = '6F74' 






47 


Check constant FID EF ACC = '6F78' 






48 


Check constant FID EF FPLMN = '6F7B' 






49 


Check constant FID EF LOCI = '6F7E' 






50 


Check constant FID EF AD = '6FAD' 






51 


Check constant FID EF PHASE = '6FAE' 






52 


Check constant FID EF VGCS = '6FB1 ' 






53 


Check constant FID EF VGCSS = '6FB2' 






54 


Check constant FID EF VBS = '6FB3' 






55 


Check constant FID EF VBSS = '6FB4' 






56 


Check constant FID EF EMLPP = '6FB5' 






57 


Check constant FID EF AAEM = '6FB6' 






58 


Check constant FID EF CBMID = '6F48' 






59 


Check constant FID EF ECC = '6FB7' 






60 


Check constant FID EF CBMIR = '6F50' 






61 


Check constant FID EF DCK = '6F2C' 






62 


Check constant FID EF CNL = '6F32' 






63 


Check constant FID EF NIA = '6F51' 






64 


Check constant FID EF KCGPRS = '6F52' 






65 


Check constant FID EF LOCIGPRS = '6F53' 






66 


Check constant FID EF SUME = '6F54' 






67 


Check constant FID EF SAI = '4F30' 






68 


Check constant FID EF SLL = '4F31' 






69 


Check constant REC ACC MODE NEXT = '02' 






70 


Check constant REC ACC MODE PREVIOUS = '03' 






71 


Check constant REC ACC MODE ABSOLUTE CURRENT = '04' 






72 


Check constant SEEK FROM BEGINNING FORWARD = 'GO' 






73 


Check constant SEEK FROM END BACKWARD = '01' 






74 


Check constant SEEK FROM NEXT FORWARD = '02' 






75 


Check constant SEEK FROM PREVIOUS BACKWARD = '03' 







6.1.1.1.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


1-75 



6.1.1.2 Method select 

Test Area Reference: API_1_SVW_ SLCTS_BSS 



6.1.1.2.1 



Conformance Requirements 



The method with the following header shall be compliant to its definition in the API. 

public short select (short fid, 
byte [ 1 f ci, 
short fciOffset, 
short fciLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
SIMViewException 



Normal execution 



CRRNl: If the desired file is selected, the length of the FCI (File Control Information) which has been written to the 
array fci is returned. 

CRRN2: If the length fciLength is greater than or equal to the length of the FCI structure, the whole FCI structure is 
copied into the array fci and the length of the FCI which has been written to the array fci is returned. 
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CRRN3: If the length fciLength is less than the length of the FCI structure, the first part of the FCI structure is 
copied into the array fci and the length of the FCI which has been written to the array fci is returned. 

CRRN4: After selecting a DF/MF no EF is selected. 

CRRN5: After selecting a linear fixed EF no record is selected. 

CRRN6: After selecting a cyclic EF the first record which is the last updated record is selected. 

CRRN7: The current files (file context) of any other applets shall not be changed. See GSM 03.19 [] - §5.2. This 
will be tested during the testing of the framework. 

CRRN8: The information returned by fci shall be formatted as described in GSM 11.11 [], §9.2.1. 

CRRN9: The file with a File-ID that matches fid shall be found according to the following selection rules: 

1) An immediate child EF or DF of the current MF/DF can be selected, 

2) A sibling DF of the current DF can be selected, 

3) The current MF/DF it self can be selected, 

4) The parent MF/DF of the current DF can be selected, 

5) The MF can always be selected. 

Parameter errors 

CRRPl: If the array fci is null, an instance of NullPointerException shall be thrown. 

CRRP2: If fciOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: If fciLength is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP4: If fciOffset plus fciLength is greater than the length of the array fci. length, or fciOffset equals fci. length, an 
instance of ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: If the file with a File-ID which matches fid could not be found according to the selection rules listed in 
CRRN9, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.FILE_NOT_FOUND. 

CRRC2: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC3: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.2.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 

Test Script: API_l_SVW_SLCTS_BSS_l.scr 

Test Applet: API_l_SVW_SLCTS_BSS_l.java 

Load Script: API_l_SVW_SLCTS_BSS_l.ldr 

Cleanup Script: API_l_SVW_SLCTS_BSS_l.clr 
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6.1.1.2.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


Select EFICCID in MF (Transparent EF) 

fid = SIMView.FID_EF_ICCID 
byte[] fci = new byte [34] 
fciOffset = 
fciLength = 20 
select ( ) 


No exception sliall be thrown. 
Shall return a value not greater 
than 20. 

<Description of fci: 

XX XX 

XX XX 

2FE2 

04 

> 




2 


Select EFicciD in MF (Transparent EF) 

fid = SIMView.FID_EF_ICCID 
fciOffset = 
fciLength = 13 
select ( ) 


No exception shall be thrown. 
Shall return 13. 

fci shall contain the first 13 bytes of 
the FCI structure. 




3 


Select DFgsm in MF 

fid = SIMView.FID_DF_GSM 
fciOffset = 
fciLength = 7 
select ( ) 


No exception shall be thrown. 

Shall return 7. 

fci shall contain the entire FCI 

structure. 

<Description of fci: 

XX XX 
XX XX 
7F 20 
02 
> 




4 


Select EFacm in DFqsm (CyclicEF) 

fid = SIMView.FID_EF_ACM 
fciOffset = 
fciLength = 20 
select 


No exception shall be thrown. 
Shall return a value between 15 
and 20. (Cyclic EF) 
fci shall contain the first 15 or more 
bytes of the FCI structure. 
fci[14] shall have the value 3 
(length of record). 




5 


Select MF 

fid = SIMView.FID_MF 
fciOffset = 
fciLength = 34 
select 


No exception shall be thrown. 

Shall return a value between 22 

and 34. 

fci shall contain the entire FCI 

structure. 




6 


Select DFtelecom in MF 

fid = SIMView.FID_DF_TELECOM 
fci[0] = fci[l] = '05' 
fciOffset = 2 
fciLength = 20 
select ( ) 


No exception shall be thrown. 
Shall return 20. 

fci shall contain the first 20 bytes of 
the FCI structure starting at index 
2. The first two bytes shall (still) 
have the value '05'. 




7 


Select EFfdn in DFtelecom (Linear FixedEF) 

fid = SIMView.FID_EF_FDN 
fciOffset = 
fciLength = 15 
select 


No exception shall be thrown. 

Shall return 15. 

fci shall contain the first 15 bytes of 

the FCI structure. 

fci[14] shall have the value 28 

(length of record). 




8 


fci is null 

fid = SIMView.FID_EF_FDN 
byte[] nullBuffer = null 
fciOffset = 
fciLength = 15 
select ( ) 


Shall throw 
java.lang.NullPointerException. 




9 


fciOffset < 

fid = SIMView.FID_EF_FDN 
fciOffset = -1 
fciLength = 15 
select ( ) 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




10 


fciLength < 

fid = SIMView.FID_EF_FDN 
fciOffset = 
fciLength = -1 
select ( ) 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




11 


fciOffset + fciLength > fci. length 


Shall throw 
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Id 


Description 


API Expectation 


APDU Expectation 




fid = SIMView.FID_EF_FDN 
fciOffset = 20 
fciLength = 15 
select 


java.lang.ArraylndexOutOfBoundsE 
xception. 




12 


fciOffset >= fci. length 

fid = SIMView.FID_EF_FDN 
fciOffset = 34 
fciLength = 1 
select 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception 




13 


Selection possibilities 

1 - fid = SIMView.FID_MF 
fciOffset = 
fciLength = 15 

select 

2 - fid = SIMView.FID_DF_TELECOM 
select 

3 - fid = SIMView.FID_DF_GRAPHICS 
select ( ) 

4 - fid = SIMView.FID_DF_TELECOM 
select ( ) 

5 - fid = SIMView.FID_DF_GRAPHICS 
select ( ) 

6 - fid = SIMView.FID„MF 
select 

7 - fid = SIMView.FID_DF_GSM 
select 

8 - fid = SIMView.FID_DF_TELECOM 
select ( ) 

9 - fid = SIMView.FID_DF_TELECOM 
select ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown. 

5 - No exception shall be thrown. 

6 - No exception shall be thrown. 

7 - No exception shall be thrown. 

8 - No exception shall be thrown. 

9 - No exception shall be thrown. 




14 


EF not selected after MF/DF selection 

1 - fid = SIMView.FID_MF 
select ( ) 

fid = SIMView.FID_EF_ICCID 
select ( ) 

2 - fid = SIMView.FID_MF 
select 

readBinary ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

Sim. access. SIMViewException with 
reason code NO_EF_SELECTED. 




15 


No selection of non-reachable file 

1 - fid = SIMView.FID_MF 
select ( ) 

2 - fid = SIMView.FID_EF_ACM 
select 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 
reason code FILE_NOT_FOUND. 




16 


No record is selected after selecting linear 
fixed EF 

1 - fid = SIMView.FID_MF 
select 

2 - fid = FID_DF_SIMTEST 
select 

3 - fid = FID_EF_LARU 
select ( ) 

4 - recNumber = 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
readRecord () 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 
4 -Shall throw 

sim. access. SIIVIViewException with 

reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 




17 


Record pointer in selected cyclic EF 

1 - fid = SIMView.FID_MF 
select ( ) 

2 - fid = FID_DF_SIMTEST 
select ( ) 

3 - fid = FID_EF_CARU 
select 

4 - byte[] datal = { 1,2,3 } 
mode = REC_ACC_MODE_PREVIOUS 
updateRecord (datal) 

5 - fid = SIMView.FID_EF_ACM 
select ( ) 

readRecord (data2) 
compare datal to data2 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown. 

5 - The contents of datal and data2 
shall be identical. 
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6.1.1.2.4 



Test Coverage 



CRR Number 


Test Case Number 


N1 


1-7 


N2 


3,5 


N3 


1,2,4,6,7 


N4 


14 


N5 


16 


N6 


17 


N8 


1,3 


N9 


1-7, 13 


P1 


8 


P2 


9 


P3 


10 


P4 


11, 12 


C1 


15 


C2, C3 


Not Tested 



6.1.1.3 



Method select 



Test Area Reference: API_1_SVW_SLCTS 

6.1.1.3.1 Conformance Requirements 

The method with the following header shall be compliant to its definition in the API. 

public void select (short fid) 

throws SIMViewException 

Normal execution 

CRRNl: If the desired file is selected, no exception is thrown. 

CRRN2: After selecting a DF/MF no EF is selected. 

CRRN3: After selecting a linear fixed EF no record is selected. 

CRRN4: After selecting a cyclic EF the first record which is the last updated record is selected. 

CRRN5: The current files (file context) of any other applets shall not be changed [03. 19 - §5.2]. This will be tested 
during the testing of the framework. 

CRRN6: The file with a File-ID that matches fid shall be found according to the following selection rules: 

1) An immediate child EF or DF of the current MF/DF can be selected, 

2) A sibling DF of the current DF can be selected, 

3) The current MF/DF it self can be selected, 

4) The parent MF/DF of the current DF can be selected, 

5) The MF can always be selected. 

Parameter errors 

This method has no errors that occur due to parameters. 

Context errors 

CRRCl: If the file with a File-ID which matches fid could not be found according to the selection rules listed in 
CCRN6, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.FILE_NOT_FOUND. 

CRRC2: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 
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CRRC3: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.3.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 

Test Script: API_l_SVW_SLCTS_l.scr 

Test Applet: API_l_SVW_SLCTS_l.java 

Load Script: API_l_SVW_SLCTS_l.ldr 

Cleanup Script: API_l_SVW_SLCTS_l.clr 
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6.1.1.3.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


Select EFicciD in MP (Transparent EF) 

fid = SIMView.FID_EF_ICCID 
select 


No exception shall be thrown. 




2 


EF not selected after MF/DF selection 

1 - fid = SIMView.FID_MF 
select ( ) 

fid = SIMView.FID_EF_ICCID 
select 

2 - fid = SIMView.FID_MF 
select 

readBinary ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

Sim. access. SIMViewException with 
reason code NO_EF_SELECTED. 




3 


No record is selected after selecting linear 
fixed EF 

1 - fid = SIMView.FID_MF 
select ( ) 

2 - fid = FID_DF„SIMTEST 
select ( ) 

3 - fid =FID_EF_LARU 
select 

4 - recNumber = 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
readRecord ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 
4 -Shall throw 

sim. access. SIIVIViewException with 

reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 




4 


Record pointer in selected cyclic EF 

1 - fid = SIMView.FID_MF 
select 

2 - fid = SIMView.FID_DF_GSM 
select 

3 - fid = SIMView.FID_EF_ACM 
select ( ) 

4 - byte[l datal = { 1,2,3 } 
updateRecord (datal) 

5 - fid = SIMView.FID_EF_ACM 
select 

readRecord (data2 ) 
compare datal to data2 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown. 

5 - The contents of datal and data2 
shall be identical. 




5 


Selection possibilities 

1 - fid = SIMView.FID_MF 
select ( ) 

2 - fid = SIMView.FID_DF_TELECOM 
select 

3 - fid = SIMView.FID_DF_GRAPHICS 
select 

4 - fid = SIMView.FID_DF_TELECOM 
select ( ) 

5 - fid = SIMView.FID_DF_GRAPHICS 
select ( ) 

6 - fid = SIMView.FID_MF 
select 

7 - fid = SIMView.FID_DF_GSM 
select 

8 - fid = SIMView.FID_DF_TELECOM 
select ( ) 

9 - fid = SIMView.FID_DF_TELECOM 
select ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown. 

5 - No exception shall be thrown. 

6 - No exception shall be thrown. 

7 - No exception shall be thrown. 

8 - No exception shall be thrown. 

9 - No exception shall be thrown. 




6 


No selection of unreachable file 

1 - fid = SIMView.FID_MF 
select 

2 - fid = SIMView.FID_EF_ACM 
select ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 
reason code FILE_NOT_FOUND. 





6.1.1.3.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


1 


CRRN2 


2 


CRRN3 


3 


CRRN4 


4 


CRRN6 


5 


CRRC1 


6 


CRRC2, CRRC3 


Not Tested 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 24 ETSI TS 101 955 V7.1.0 (2001-06) 

6.1.1.4 Method Status 

Test Area Reference: API_1_SVW_STAT_BSS 

6.1.1.4.1 Conformance Requirements 

The method with the following header shall be compliant to its definition in the API. 

public short status (byte [ ] fci, 

short fciOffset, 
short fciLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
SIMViewException 

Normal execution 

CRRNl: The FCI (File Control Information) of the current DF (or MF) is returned in the same format as for a 
SELECT command in case of selecting an MF/DF (described in GSM 03. 19 [], §9.2. 1). 

CRRN2: If the length fciLength is greater than or equal to the length of the FCI structure, the whole FCI structure is 
copied into the array fci and the length of the FCI which has been written to the array fci is returned. 

CRRN3: If the length fciLength is less than the length of the FCI structure, the first part of the FCI structure is 
copied into the array fci and the length of the FCI which has been written to the array fci is returned. 

Parameter errors 

CRRPl: If the array fci is null, an instance of NullPointerException shall be thrown. 

CRRP2: If fciOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: If fciLength is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP4: If fciOffset plus fciLength is greater than the length of the array fci. length, or fciOffset equals fci. length, an 
instance of ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRC 1 : If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC2: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.4.2 Test Suite Files 
Additional requirements for the GSM personalisation: 

Test Script: API_l_SVW_STAT_BSS_l.scr 

Test Applet: API_l_SVW_STAT_BSS_l.java 

Load Script: API_l_SVW_STAT_BSS_l.ldr 

Cleanup Script: API_l_SVW_STAT_BSS_l.cb- 
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6.1.1.4.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


Status of MF 

byte[] fci = new byte [34] 
fciOffset = 
fciLength = 7 
status 


No exception sliall be thrown. 

Shall return 7. 

fci shall contain the entire FCI 

structure. 

<Description of fci: 

XX XX 

XX XX 

3F00 

01 

> 




2 


Status after select EFiccid in MF 

1 - fid = SIMView.FID_DF_GSM 
fciOffset = 

fciLength = 34 
len = select ( ) 

2 - byte[] fci2 = new byte [34] 

len2 = status ( ) 

3 - Compare len and len2 

4 - Compare tine len bytes of fci and fci2 


1 - No exception shall be thrown. 
Shall return a value between 22 
and 34. 

2 - No exception shall be thrown. 
Shall return 22 or more. 

3 - len and Ien2 shall be identical 

4 - fci and fci2 shall be identical 




3 


Status of DFielecom 

1 - fid = SIMView.FID_DF_TELECOM 
select ( ) 

2 - fciOffset = 
fclLengtli = 100 
status 


1 - No exception shall be thrown. 
Shall return a value between 22 
and 34. 

2 - No exception shall be thrown. 
Shall return a value between 22 
and34. 

fci shall contain the entire FCI 
structure (check that returned value 
is equal to 13 plus the "length of 
following data" - fci[12]).FID of the 
returned fci (fci[4:5]) is 
FID_DF_TELECOM. 




4 


Status DFtelecom 

fciOffset = 
fciLength = 7 
status 


No exception shall be thrown. 

Shall return 7. 

fci shall contain the first 7 bytes of 

the FCI structure starting at index 

0. 

FID of the returned fci (fci[4:5]) is 

FID DF TELECOM. 




5 


fci is null 

byte[] nullBuffer = null 
fciOffset = 
fciLength = 34 
status 


Shall throw 
java.lang.NullPointerException. 




6 


fciOffset < 

fciOffset = -1 
fciLength = 34 
status 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




7 


fciLength < 

fciOffset = 
fciLength = -1 
status 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




8 


fciOffset + fciLength > fci. length 

fciOffset = 20 
fciLength = 15 
status 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




9 


fciOffset >= fci. length 

fciOffset = 34 
fciLength = 1 
status 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 





6.1.1.4.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


1-4 


CRRN2 


2,3 
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CRR Number 


Test Case Number 


CRRN3 


1,4 


CRRP1 


5 


CRRP2 


6 


CRRP3 


7 


CRRP4 


8,9 


CRRC1,CRRC2 


Not Tested 



6.1 .1 .5 Method readBinary 

Test Area Reference: API 1 SVW REDBS BSS 



6.1.1.5.1 



Conformance Requirements 



The method with the following header shall be compliant to its definition in the API. 

public short readBinary (short fileOffset, 

byte [ ] resp, 
short respOffset, 
short respLength) 
throws Java . lang.NullPointerException, 

Java. lang. ArraylndexOutOfBoundsException, 
SIMViewException 

Normal execution 

CRRNl: If data can be accessed at the specified offset, the value respOffset plus respLength are returned and the 
data bytes of the currently selected transparent file are returned in resp. 

Parameter errors 

CRRP 1 : If fileOffset is less than 0, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.OUT_OF_FILE_BOUNDARIES. 

CRRP2: If fileOffset plus respLength exceeds the length of the file, an instance of SIMViewException shall be 
thrown. The reason code shall be SIMViewException.OUT_OF_FILE_BOUND ARIES. 

CRRP3: If the array resp is null, an instance of NulIPointerException shall be thrown. 

CRRP4: If respOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP5: If respLength is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP6: If respOffset plus respLength is greater than the length of the array resp. length, an instance of 
ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: If the calling applet has currently no EF selected, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.NO_EF_SELECTED. 

CRRC2: If the currently selected EF is not transparent, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.FILEJNCONSISTENT. 

CRRC3: If the calling applet does not fulfil the access condition, READ, to perform this function, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException. AC_NOT_FULFILLED. 

CRRC4: If the currently selected EF is invalidated and the file status of the EF does not allow for the reading of an 
invalidated file, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.INVALIDATION_STATUS_CONTRADICTION. 

CRRC5: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC6: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 
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6.1.1.5.2 Test Suite Files 

Additional requirements for tlie GSM personalisation: none. 

Test Script: API_l_SVW_REDBS_BSS_l.scr 

Test Applet: API_l_SVW_REDBS_BSS_l.java 

Load Script: API_l_SVW_REDBS_BSS_l.ldr 

Cleanup Script: API_l_SVW_REDBS_BSS_l.clr 



6.1.1.5.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored 




1 


Read from EFICCID in MF (Transparent EF) 

1 - fid = SIMView.FID_EF_ICCID 
select 

2 - fileOffset = 
byte[] resp = new byte [20] 
resp[0:191 = '55' 
respOffset = 10 
respLength = 10 
readBinary ( ) 


1 - No exception sliall be thrown. 

2 - No exception sliall be thrown. 
Shall return 20. 

resp shall contain the entire 

contents of EFICCID starting at 

index 10. 

<Description of resp: 

55 55 55 55 55 55 55 55 55 55 

OF FF FF FF FF FF FF FF FF FF 

> 




2 


Read from EFICCID in MF 

resp[0:19] = '55' 
fileOffset = 5 
respOffset = 10 
respLength = 5 
readBinary ( ) 


No exception shall be thrown. 

Shall return 15. 

resp shall contain the last 5 bytes 

of EFICCID starting at index 10. 

<Description of resp: 

55 55 55 55 55 55 55 55 55 55 

FFFFFFFFFF55 55 55 55 55 

> 




3 


Offset into File out of bounds 

fileOffset = -1 
respOffset = 
respLength = 10 
readBinary ( ) 


Shall throw 

Sim. access. SIMViewException with 

reason code 

OUT_OF_FILE_BOUNDARIES. 




4 


fileOffset + respLength > EF length 

fileOffset = 9 
respOffset = 
respLength = 2 
readBinary ( ) 


Shall throw 

Sim. access. SIIVIViewException with 

reason code 

OUT_OF_FILE_BOUNDARIES. 




5 


resp is null 

byte[] nullBuffer = null 
fileOffset = 
respOffset = 
respLength = 10 
readBinary ( ) 


Shall throw 
java.lang.NullPointerException. 




6 


respOffset < 

fileOffset = 
respOffset = -1 
respLength = 10 
readBinary ( ) 


Shall throw 

java.lang. 

Array IndexOutOfBoundsException. 




7 


respLength < 

fileOffset = 
respOffset = 
respLength = -1 
readBinary ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




8 


respOffset + respLength > resp.length 

fileOffset = 
respOffset = 10 
respLength = 11 
readBinary ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 
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Id 


Description 


API Expectation 


APDU Expectation 


9 


EF is not Transparent 

1 - fid = FID_DF_SIMTEST 
select 

2 - fid = FID_EF_LARU 
select ( ) 

3 - fileOffset = 
respOffset = 
respLength = 1 
readBinary ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - Shall throw 

Sim. access. SIIVIViewException with 
reason code 
FILEJNCONSISTENT. 




10 


Access condition not fulfilled 


Shall throw 






1 - fid = DFSIMTTEST 
select ( ) 

2 - fid = EFTNR 
select 


sim. access. SIIVIViewException with 
reason code 
AC_NOT_FULFILLED. 






3 - fileOffset = 








respOffset = 








respLength = 1 








readBinary ( ) 






11 


EF is invalidated 

1 - fid = EFTNU 


1 - No exception shall be thrown. 

2 - Shall throw 






invalidate ( ) 

2 - readBinary ( ) 

3 - rehabilitate ( ) 


sim. access. SIIVIViewException with 

reason code 

INVALIDATION STATUS CONTR 

ADICTION. 

3 - No exception shall be thrown. 




12 


No EF selected 

1- fid = SIMView.FID_MF 


1 - No exception shall be thrown. 

2 - Shall throw 






select 

2 readBinary ( ) 


sim. access. SIIVIViewException with 
reason code NO EF SELECTED. 





6.1.1.5.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


1-2 


CRRP1 


3 


CRRP2 


4 


CRRP3 


5 


CRRP4 


6 


CRRP5 


7 


CRRP6 


8, 


CRRC1 


12 


CRRC2 


9 


CRRC3 


10 


CRRC4 


11 


CRRC5, CRRC6 


Not Tested 



6.1 .1 .6 Method updateBinary 

Test Area Reference: API 1 SVW UPDBS BSS 



6.1.1.6.1 



Conformance Requirements 



The method with the following header shall be compliant to its definition in the API. 

public void updateBinary (short fileOffset, 

byte [ ] data, 
short dataOffset, 
short dataLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
SIMViewException 

Normal execution 

CRRN 1 : The currently selected transparent file is updated starting at fileOffset, with the string of dataLength bytes 
in the array data starting at dataOffset. 
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Parameter errors 

CRRP 1 : If fileOffset is less than 0, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.OUT_OF_FILE_BOUNDARIES. 

CRRP2: If fileOffset plus dataLength exceeds the length of the file, an instance of SIMViewException shall be 
thrown. The reason code shall be SIM ViewException.OUT_OF_FILE_BOUND ARIES. 

CRRP3: If the array data is null, an instance of NullPointerException shall be thrown. 

CRRP4: If dataOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP5: If dataLength is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP6: If dataOffset plus dataLength greater than the length of the array data.length an instance of 
ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: If the calling applet has currently no EF selected, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.NO_EF_SELECTED. 

CRRC2: If the currently selected EF is not transparent, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.FILEJNCONSISTENT. 

CRRC3: If the calling applet does not fulfil the access condition, UPDATE, to perform this function, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException. AC_NOT_FULFILLED. 

CRRC4: If the currently selected EF is invalidated and the file status of the EF does not allow for updating of an 
invalidated file, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.INVALIDATION_STATUS_CONTRADICTION. 

CRRC5: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC6: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.6.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 

Test Script: API_l_SVW_UPDBS_BSS_l.scr 

Test Applet: API_l_SVW_UPDBS_BSS_l.java 

Load Script: API_l_SVW_UPDBS_BSS_l.ldr 

Cleanup Script: API_l_SVW_UPDBS_BSS_l.clr 
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6.1.1.6.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


No EF selected 

fileOffset = 
byte[] data = new byte [20] 
data[0] = '55' 
dataOffset = 
dataLength = 10 
updateBinary ( ) 


Shall throw 

Sim. access. SIMViewException with 

reason code NO_EF_SELECTED. 




2 


Update Transparent EF 

1 - fid = DFSIMTEST 
select 

2 - fid = EFTARU 
select ( ) 

3 - fileOffset = 3 
data[0] = '55' 
dataOffset = 
dataLength = 1 
updateBinary ( ) 

4 - fileOffset = 3 
respOffset = 
respLength = 1 
readBinary ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown. 
Data in resp[0] shall be '55'. 




3 


1 - fileOffset = 254 

data[0] = '55' 
data[ll = 'AA' 
data[21 = '66' 
dataOffset = 
dataLength = 3 
updateBinary ( ) 
2 - fileOffset = 254 
respOffset = 
respLength = 3 
readBinary ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 
Data in resp shall be 

resp[0] = '55' 
resp[1] = 'AA' 
resp[2] = '66' 




4 


Offset into File out of bounds 

fileOffset = -1 
dataOffset = 
dataLength = 10 
updateBinary ( ) 


Shall throw 

sim. access. SIMViewException with 

reason code 

OUT_OF_FILE_BOUNDARIES. 




5 


fileOffset + dataLength > EF length 

fileOffset = 259 
dataOffset = 
dataLength = 2 
updateBinary ( ) 


Shall throw 

sim. access. SIIVIViewException with 

reason code 

OUT_OF_FILE_BOUNDARIES. 




6 


data is null 

byte[] nullBuffer = null 
fileOffset = 
dataOffset = 
dataLength = 10 
updateBinary ( ) 


Shall throw 
java.lang.NullPointerException. 




7 


dataOffset < 

fileOffset = 

dataOffset = -1 
dataLength = 10 
updateBinary ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




8 


dataLength < 

fileOffset = 
dataOffset = 
dataLength = -1 
updateBinary ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




9 


dataOffset + dataLength > data.length 

fileOffset = 
dataOffset = 10 
dataLength = 11 
updateBinary ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 
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Id 


Description 


API Expectation 


APDU Expectation 


10 


EF is not Transparent 

1 - fid = FID_DF_SIMTEST 
select 

2 - fid = FID_EF_LARU 
select ( ) 

3 - fileOffset = 
data[0] = '55' 
dataOffset = 
dataLength = 1 
updateBinary ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - Shall throw 

Sim. access. SIIVIViewException with 
reason code 
FILEJNCONSISTENT. 




11 


Access condition not fulfilled 

1 - fid = DFSIMTEST 
select ( ) 

fid = EFTNU 
select 

2 - fileOffset = 
data[0] = '55' 
dataOffset = 
dataLength = 1 
updateBinary ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 
reason code 
AC_NOT_FULFILLED. 




12 


EF is invalidated 

1 - fid = EFTNR 
invalidate ( ) 

2 - fileOffset = 
data[0] = '55' 
dataOffset = 
dataLength = 1 
updateBinary ( ) 

3 - rehabilitate ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

INVALIDATION STATUS CONTR 

ADICTION. 

3 - No exception shall be thrown. 





6.1.1.6.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


2,3 


CRRP1 


4 


CRRP2 


5 


CRRP3 


6 


CRRP4 


7 


CRRP5 


8 


CRRP6 


9 


CRRC1 


1 


CRRC2 


10 


CRRC3 


11 


CRRC4 


12 


CRRC5, CRRC6 


Not Tested 



6.1 .1 .7 Method readRecord 



Test Area Reference: API 1 SVW REDRSBS BSS 



6.1.1.7.1 



Conformance Requirements 



The method with the following header shall be compliant to its definition in the API. 

public short readRecord (short recNumber^ 

byte mode, 
short recOffset, 
byte [ ] resp, 
short respOffset, 
short respLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
SIMViewException 

Normal execution 

CRRNl: The data bytes from the record, specified by mode and recNumber of the currently selected linear fixed or 
cyclic EF, is read at recOffset. A total of respLength bytes of this data is copied to the array resp at respOffset. 

CRRN2: If the access mode is REC ACC MODE ABSOLUTE CURRENT: 
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if recNumber is not 0, the record addressed by recNumber will be read; 

if recNumber is the current selected record will be read; and 

the current record pointer shall not change. 

CRRN3: If the access mode is REC_ACC_MODE_NEXT: 

the next record relative to the current selected record will be selected and read; 

if no current record is selected, the first record will be selected and read; 

if the current record pointer is set to the last record for a cyclic EF the record pointer is set to the first record 
and the record is read; 

the current record pointer of any other applet shall not be changed. 

CRRN4: If the access mode is REC_ACC_MODE_PREVIOUS: 

the previous record relative to the current selected record will be selected and read; 

if no current record is selected, the last record will be selected and read; 

if the current record pointer is set to the first record, for a linear fixed EF the method responses with an error 
exception and for a cyclic EF the record pointer is set to the last record and the record is read; 

the current record pointer of any other applet shall not be changed. 

Parameter errors 

CRRPl: If the currently selected EF is linear fixed and the access mode is 

REC_ACC_MODE_ABSOLUTE_CURRENT and recNumber is less than or greater than records available, an 
instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.RECORD_NUMBER_NOT_AVAILABLE. 

CRRP2: If the currently selected EF is linear fixed and the access mode is 

REC_ACC_MODE_ABSOLUTE_CURRENT, recNumber is and there is no current record selected, an 
instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.RECORD_NUMBER_NOT_AVAILABLE. 

CRRP3: If the currently selected EF is linear fixed and the access mode is REC_ACC_MODE_NEXT and the 
current record pointer is set to the last record, an instance of SIMViewException shall be thrown. The reason 
code shall be SIMViewException.RECORD_NUMBER_NOT_AVAILABLE. 

CRRP4: If the currently selected EF is linear fixed and the access mode is REC_ACC_MODE_PREVIOUS and the 
current record pointer is set to the first record, an instance of SIMViewException shall be thrown. The reason 
code shall be SIMViewException.RECORD_NUMBER_NOT_AVAILABLE. 

CRRP5: If the specified offset into the selected record recOffset is less than 0, an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.OUT_OF_RECORD_BOUND ARIES. 

CRRP6: If recOffset plus resp Length is greater than the record length, an instance of SIMViewException shall be 
thrown. The reason code shall be SIMViewException.OUT_OF_RECORD_BOUND ARIES. 

CRRP7: If the access mode is not between 2 and 4 inclusive (2 = REC_ACC_MODE_NEXT, etc.), an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException. INVALID_MODE. 

CRRP8: If the array resp is null, an instance of NullPointerException shall be thrown. 

CRRP9: If respOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRPIO: If respLength is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP 11 : If respOffset plus respLength is greater than the length of the array resp. length, or respOffset equals 
resp. length, an instance of ArraylndexOutOfBoundsException shall be thrown. 
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Context errors 

CRRC 1 : If the calling applet has currently no EF selected, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.NO_EF_SELECTED. 

CRRC2: If the currently selected EF is neither linear fixed nor cyclic, an instance of SIMViewException shall be 
thrown. The reason code shall be SIMViewException.FILE_INCONSISTENT. 

CRRC3: If the calling applet does not fulfil the access condition, READ, to perform this function, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException. AC_NOT_FULFILLED. 

CRRC4: If the currently selected EF is invalidated and the file status of the EF does not allow for reading an 
invalidated file, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.INVALIDATION_STATUS_CONTRADICTION. 

CRRC5: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC6: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 



6.1.1.7.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 



Test Script: 
Test Applet: 
Load Script: 
Cleanup Script: 



API_1_S VW_REDRSBS_BSS_1 .scr 
API_l_SVW_REDRSBS_BSS_l.java 
API_1_S VW_REDRSBS_BSS_1 .Idr 
API_l_SVW_REDRSBS_BSS_l.clr 



6.1.1.7.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


No EF selected 


Shall throw 






recNumber = 1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 

recOffset = 


Sim. access. SIMViewException with 
reason code NO_EF_SELECTED. 






byte[] resp = new byte [20] 








respOffset = 








respLength = 10 








readRecord ( ) 
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Id 


Description 


API Expectation 


APDU Expectation 


2 


Read Absolute and Current from Linear Fixed 
EF 

1 - fid = DFSIMTEST 
select ( ) 

2 - fid = EFLARU 
select 

// Record pointer not set. 

3 - recNumber = 

mode = REC_ACC_MODE_NEXT 
recOffset = 
respOffset = 
respLength = 4 
readRecord ( ) 

4 - recNumber = 2 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
readRecord ( ) 

5 - recNumber = 1 
readRecord ( ) 

6 - recNumber = 

resp[0] = resp[l] = resp[2] = resp[3] = 

'00' 

readRecord ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown, 
resp shall be: 

resp[0] = '55' 
resp[1] = '55' 
resp[2] = '55' 
resp[3] = '55' 

4 - No exception shall be thrown, 
resp shall be: 

resp[0] = 'AA' 
resp[1] = 'AA' 
resp[2] = 'AA' 
resp[3] = 'AA' 

5 - No exception shall be thrown, 
resp shall be: 

resp[0] = '55' 
resp[1] = '55' 
resp[2] = '55' 
resp[3] = '55' 

6 - No exception shall be thrown, 
resp shall be: 

resp[0] = '55' 
resp[1] = '55' 
resp[2] = '55' 
resp[3] = '55' 




3 


Read Next from Linear Fixed EF 

recNumber = 
mode = REC_ACC_MODE_NEXT 
recOffset = 
respOffset = 
respLength = 4 
readRecord ( ) 


No exception shall be thrown. 

resp shall be: 

resp[0] = 'AA' 

resp[1] = 'AA' 

resp[2] = 'AA' 

resp[3] = 'AA' 




4 


Read Next from Linear Fixed EF 

recNumber = 
mode = REC_ACC_MODE_NEXT 
recOffset = 
respOffset = 
respLength = 4 
readRecord ( ) 


Shall throw 

Sim. access. SIMViewException with 

reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 




5 


Read Previous from Linear Fixed EF 

recNumber = 

mode = REC_ACC_MODE_PREVIOUS 

recOffset = 

respOffset = 

respLength = 4 

readRecord ( ) 


No exception shall be thrown. 

resp shall be: 

resp[0] = '55' 

resp[1] = '55' 

resp[2] = '55' 

resp[3] = '55' 




6 


Read Previous from Linear Fixed EF 

recNumber = 

mode = REC_ACC_MODE_PREVIOUS 

recOffset = 

respOffset = 

respLength = 4 

readRecord ( ) 


Shall throw 

Sim. access. SIMViewException with 

reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 
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Id 


Description 


API Expectation 


APDU Expectation 


7 


Read Absolute and Current from Cyclic EF 

1 - fid = EFCARU 
select 

2 - recNumber = 2 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = 
respOffset = 
respLength = 3 
readRecord ( ) 

3 - recNumber = 1 
readRecord ( ) 

4 - recNumber = 

resp[0] = resp[l] = resp[2] = '00 
readRecord ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown, 
resp shall be: 

resp[0] = ' AA' 
resp[1] = 'AA' 
resp[2] = ' AA' 

3 - No exception shall be thrown, 
resp shall be: 

resp[0] = '55' 
resp[1] = '55' 
resp[2] = '55' 

4 - No exception shall be thrown, 
resp shall be: 

resp[0] = '55' 
resp[1] = '55' 
resp[2] = '55' 




8 


Read Next from Cyclic EF 

recNumber = 
mode = REC_ACC_MODE_NEXT 
recOffset = 
respOffset = 
respLength = 3 
readRecord ( ) 


No exception shall be thrown, 
resp shall be: 
resp[0] = 'AA' 
resp[1] = 'AA' 
resp[2] = 'AA' 




9 


Read Next from Cyclic EF 

recNumber = 
mode = REC_ACC_MODE_NEXT 
recOffset = 
respOffset = 
respLength = 3 
readRecord () 


No exception shall be thrown, 
resp shall be: 
resp[0] = '55' 
resp[1] = '55' 
resp[2] = '55' 




10 


Read Previous from Cyclic EF 

recNumber = 

mode = REC_ACC_MODE_PREVIOUS 

recOffset = 

respOffset = 

respLength = 3 

readRecord ( ) 


No exception shall be thrown, 
resp shall be: 
resp[0] = 'AA' 
resp[1] = 'AA' 
resp[2] = 'AA' 




11 


Read Previous from Cyclic EF 

recNumber = 

mode = REC_ACC_MODE_PREVIOUS 

recOffset = 

respOffset = 

respLength = 3 

readRecord ( ) 


No exception shall be thrown, 
resp shall be: 
resp[0] = '55' 
resp[1] = '55' 
resp[2] = '55' 




12 


Read Absolute from Linear Fixed EF beyond 

Records 

1 - fid = EFLARU 
select 

2 - recNumber = -1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = 
respOffset = 
respLength = 4 
readRecord ( ) 

3 - recNumber = 3 
readRecord ( ) 


1 - No exceptionshall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 

3 - Shall throw 

sim. access. SIIVIViewException with 

reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 




13 


No current record in linear fixed EF, read 

current 

1 - fid = EFLARU 

select // No curr rec 

2 - recNumber =0 // curr rec 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = 
respOffset = 
respLength = 4 
readRecord ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 
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Id 


Description 


API Expectation 


APDU Expectation 


14 


recOffset < 

1 - fid = EFLARU 
select 

2 - recNumber =1 // rec 1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = -1 
respOffset = 
respLength = 4 
readRecord ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

Sim. access. SIMViewException with 

reason code 

OUT OF RECORD BOUNDARIE 

S. 




15 


recOffset + respLength > Record Length 

1 - fid = EFLARU 
select ( ) 

2 - recNumber = 1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = 2 
respOffset = 
respLength = 4 
readRecord ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

Sim. access. SIIVIViewException with 

reason code 

OUT OF RECORD BOUNDARIE 

S. 




16 


Reading with invalid mode 

1 - fid = EFLARU 
select 

2 - recNumber = 
mode = 1 
recOffset = 
respOffset = 
respLength = 4 
readRecord ( ) 

3 - mode = 5 
readRecord ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 
reason code INVALID_MODE. 

3 - Shall throw 

sim. access. SIMViewException with 
reason code INVALID_MODE. 




17 


resp is null 

byte[] nullBuffer = null 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 

respOffset = 

respLength = 10 

readRecord ( ) 


Shall throw 
java.lang.NullPointerException. 




18 


respOffset < 

respOffset = -1 
respLength = 10 
readRecord ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




19 


respLength < 

respOffset = 
respLength = -1 
readRecord () 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




20 


respOffset + respLength > resp.length 

respOffset = 10 
respLength = 11 
readRecord () 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




21 


EF is neither Cyclic nor Linear Fixed 

1 - fid = DFSIMTEST 
select 

2 - fid = EFTNU 
select 

3 - respOffset = 
respLength = 4 
readRecord ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - Shall throw 

sim. access. SIMViewException with 
reason code 
FILEJNCONSISTENT. 




22 


Access condition not fulfilled 

1 - fid = EFCNR 
select 

2 - readRecord 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

AC NOT FULFILLED. 




23 


EF is invalidated 

1 - fid = EFCNU 
invalidate ( ) 

2 - readRecord 

3 - rehabilitate 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

INVALIDATION STATUS CONTR 

ADICTION. 

3 - No exception shall be thrown. 
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6.1.1.7.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


2-5,7-11 


CRRN2 


2,7 


CRRN3 


3,8,9 


CRRN4 


5, 10, 11 


CRRP1 


12 


CRRP2 


13 


CRRP3 


4 


CRRP4 


6 


CRRP5 


14 


CRRP6 


15 


CRRP7 


16 


CRRP8 


17 


CRRP9 


18 


CRRP10 


19 


CRRP11 


20 


CRRC1 


1 


CRRC2 


21 


CRRC3 


22 


CRRC4 


23 


CRRC5, CRRC6 


Not Tested 



6.1 .1 .8 Method updateRecord 

Test Area Reference: API_1_SVW_UPDRSBS_BSS 

6.1.1.8.1 Conformance Requirements 

The method with the following header shall be compliant to its definition in the API. 

public void updateRecord (short recNumber, 

byte mode, 
short recOffset, 
byte [ ] data, 
short dataOffset, 
short dataLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
SIMViewException 

Normal execution 

CRRNl: dataLength bytes of the record specified by mode and recNumber of the current selected linear fixed or 
cyclic EF are updated at recOffset, by using the string of bytes in the array data starting at dataOffset. 

CRRN2: If the access mode is REC_ACC_MODE_ABSOLUTE_CURRENT and the file is a linear fixed EF: 

the record addressed by recNumber will be updated; 

if recNumber is the current selected record will be updated; and 

the current record pointer shall not change. 
CRRN3: If the access mode is REC_ACC_MODE_NEXT and the file is a linear fixed EF: 

the next record relative to the current selected record will be selected and updated; 

if no current record is selected, the first record will be selected and updated; 

the current record pointer of any other applet shall not be changed. 
CRRN4: If the access mode is REC_ACC_MODE_PREVIOUS: 

the previous record relative to the current selected record will be selected and updated; 

if no current record is selected, the last record will be selected and updated; 
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if a cyclic EF is updated, the oldest record will be updated independent of the current record pointer and this 
record becomes record number 1 and the current record; 

the current record pointer of any other applet shall not be changed in case of a linear fixed EF. 

Parameter errors 

CRRPl: If the currently selected EF is linear fixed and the access mode is 

REC_ACC_MODE_ABSOLUTE_CURRENT and recNumber is less than or greater than records available, an 
instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.RECORD_NUMBER_NOT_AVAILABLE. 

CRRP2: If the currently selected EF is linear fixed and the access mode is 

REC_ACC_MODE_ABSOLUTE_CURRENT, recNumber is and there is no current record selected, an 
instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.RECORD_NUMBER_NOT_AVAILABLE. 

CRRP3: If the currently selected EF is linear fixed and the access mode is REC_ACC_MODE_NEXT and the 
current record pointer is set to the last record, an instance of SIMViewException shall be thrown. The reason 
code shall be SIMViewException.RECORD_NUMBER_NOT_AVAILABLE. 

CRRP4: If the currently selected EF is linear fixed and the access mode is REC_ACC_MODE_PREVIOUS and the 
current record pointer is set to the first record; an instance of SIMViewException shall be thrown. The reason 
code shall be SIMViewException.RECORD_NUMBER_NOT_AVAILABLE. 

CRRP5: If the specified offset into the selected record recOffset is less than 0, an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.OUT_OF_RECORD_BOUND ARIES. 

CRRP6: If recOffset plus dataLength is greater than the record lengh, an instance of SIMViewException shall be 
thrown. The reason code shall be SIM ViewException.OUT_OF_RECORD_BOUND ARIES. 

CRRP7: If the access mode is not between 2 and 4 inclusive (2 = REC_ACC_MODE_NEXT, etc.), an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException. INVALID_MODE. 

CRRP8: If the currently selected EF is cyclic and the mode of record access mode is not 

REC_ACC_MODE_PREVIOUS, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.INVALID_MODE. 

CRRP9: If the array data is null, an instance of NullPointerException shall be thrown. 

CRRPIO: If dataOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRPll: If dataLength is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRPl 2: If dataOffset plus dataLength, is greater than the length of the array data. length, or dataOffset equals 
data.length, an instance of ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: If the calling applet has currently no EF selected, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.NO_EF_SELECTED. 

CRRC2: If the currently selected EF is neither linear fixed nor cyclic, an instance of SIMViewException shall be 
thrown. The reason code shall be SIMViewException.FILEJNCONSISTENT. 

CRRC3: If the calling applet does not fulfil the access condition, UPDATE, to perform this function, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException. AC_NOT_FULFILLED. 

CRRC4: If the currently selected EF is invalidated and the file status of the EF does not allow for updating an 
invalidated file, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.INVALIDATION_STATUS_CONTRADICTION. 

CRRC5: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 
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CRRC6: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.8.2 Test Suite Files 

Additional requirements for the GSM personalisation: This test is based on the assumption that the contents of the EFs 
in DFsiMTEST are identical to those defined in the default pre-personalisation and the current record pointers have not 
been altered. 

Test Script: API_l_SVW_UPDRSBS_BSS_l.scr 

Test Applet: API_l_SVW_UPDRSBS_BSS_l.java 

Load Script: API_l_SVW_UPDRSBS_BSS_l.ldr 

Cleanup Script: API_l_SVW_UPDRSBS_BSS_l.clr 
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6.1.1.8.3 



Test Procedure 



id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


No EF selected 

recNumber = 1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 

recOffset = 

byte[] data = new byte [20] 

dataOffset = 

dataLength = 10 

updateRecord ( ) 


Shall throw 

Sim. access. SIIVIViewException with 

reason code NO_EF_SELECTED. 




2 


Update Absolute and Current from Linear 
Fixed EF 

1 - fid = DFSIMTEST 
select ( ) 

2 - fid = EFLARU 
select 

// Record pointer not set. 

3 - recNumber = 2 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 

data [0:3] = '11' 

recOffset = 

dataOffset = 

dataLength = 4 

updateRecord ( ) 

respOffset = 

respLength = 

readRecord ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 
Resp shall be: 

Resp[0] = '11' 
Resp[1] = '11' 
Resp[2] = '11' 
Resp[3] = '11' 


= 4 


3 


Update Current from Linear Fixed EF 

1 - fid = DFSIMTEST 
select 

2 - fid = EFLARU 
select ( ) 

// Set record pointer with mode "next". 

3 - recNumber = 

mode = REC_ACC_MODE_NEXT 

recOffset = 

data[0:3] = "00' 

dataOffset = 

dataLength = 4 

updateRecord () 

// write data with mode "current" 

4 - recNumber = 
data[0:3] = '22' 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 

updateRecord ( ) 

// read result with mode "absolute" 

respOffset = 

respLength = 4 

recNumber = 1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 

readRecord ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown, 
resp shall be: 

resp[0] = '22' 
resp[1] = '22' 
resp[2] = '22' 
resp[3] = '22' 




4 


Update Next from Linear Fixed EF, no record 
pointer set 

1 - fid = FID_DF_SIMTEST 
select ( ) 

2 - fid = FID_EF_LARU 
select 

3 - recNumber = 

mode = REC_ACC_MODE_NEXT 

recOffset = 

data[0:3] = '33' 

dataOffset = respOffset = 

dataLength = respLength = 4 

updateRecord ( ) 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 

readRecord () 


1 - No exception shall be thrown. 
2- No exception shall be thrown. 
3 - No exception shall be thrown. 
Resp shall be: 
Resp[0] = '33' 
Resp[1] = '33' 
Resp[2] = '33' 
Resp[3] = '33' 




5 


Update Next from Linear Fixed EF, record 
pointer set 

1 - recNumber = 
mode = REC_ACC_MODE_NEXT 
recOffset = 
data[0:3] = M4' 


1 - No exception shall be thrown. 

2 - No exception shall be thrown, 
resp shall be: 

resp[0] = '44' 
resp[1] = '44' 
resp[2] = '44' 
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Id 


Description 


API Expectation 


APDU Expectation 




dataOffset = 

dataLength = 4 

updateRecord () 

2 - mode = REC_ACC_MODE_ABSOLUTE_CURRENT 

readRecord ( ) 


resp[3] = '44' 
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Id 


Description 


API Expectation 


APDU Expectation 


6 


Update Next from Linear Fixed EF, no more 


Shall throw 






records 


sim. access. SIMViewException with 






recNumber = 


reason code 






mode = REC_ACC_MODE_NEXT 


RECORD NUMBER NOT AVAIL 






recOffset = 


ABLE. 






data[0:3] = '55' 








dataOffset = 








dataLength = 4 








updateRecord ( ) 






7 


Update Previous from Linear Fixed EF, no 


1 - No exception shall be thrown. 






record pointer set 


2 - No exception shall be thrown. 






1 - fid = DFSIMTEST 


3 - No exception shall be thrown. 






select ( ) 


4 - No exception shall be thrown. 






2 - fid = EFLARU 


resp shall be: 






select ( ) 

3 - recNumber = 


resp[0] = '66' 






mode = REC„ACC_MODE_PREVIOUS 


resp[1] = '66' 






recOffset = 


resp[2] = '66' 






data[0:3] = "66' 


resp[3] = '66' 






dataOffset = respOffset = 








dataLength = respLength = 4 








updateRecord ( ) 








4 - mode = REC_ACC_MODE_ABSOLUTE_CURRENT 








readRecord ( ) 






8 


Update Previous from Linear Fixed EF, record 


1 - No exception shall be thrown 






pointer set 


2 - No exception shall be thrown. 






1 - recNumber = 


Resp shall be: 






mode = REC_ACC_MODE_PREVIOUS 


Resp[0] = '7744' 






recOffset = 
data[0:3] = '77' 
dataOffset = respOffset = 


Resp[1] = '7744' 
Resp[2] = '7744' 






dataLength = respLength = 4 


Resp[3] = '7744' 






updateRecord ( ) 








readRecord ( ) 








2 - mode = REC_ACC_MODE_ABSOLUTE_CURRENT 






9 


Update Previous from Linear Fixed EF , no 


Shall throw 






more records 


sim. access. SIIVIViewException with 






recNumber = 


reason code 






mode = REC_ACC_MODE_PREVIOUS 


RECORD NUMBER NOT AVAIL 






recOffset = 


ABLE. 






data [0:3] = '88' 








dataOffset = respOffset = 








dataLength = respLength = 4 








updateRecord ( ) 






10 


Update Previous from Cyclic EF 


1 - No exception shall be thrown. 






1 - fid = FID_DF_SIMTEST 


2 - No exception shall be thrown. 






select 


3 - No exception shall be thrown. 






2 - fid = FID_EF_CARU 
select 

3 — recNumber = 2 


4 - No exception shall be thrown. 






5 - No exception shall be thrown. 






mode = REC_ACC_MODE_ABSOLUTE_CURRENT 


resp shall be: 






recOffset = 


resp[0] = data[0] 






respOffset = 


resp[1] = data[1] 






respLength = 3 


resp[2] = data[2] 






readRecord ( ) 








4 - recNumber = 2 








mode = REC_ACC_MODE_PREVIOUS 








data[0:2] = resp[0:2] " 'FF' 








dataOffset = 








dataLength = 3 








updateRecord ( ) 








5 - recNumber = 








mode = REC_ACC_MODE_ABSOLUTE_CURRENT 








respOffset = 








respLength = 3 








readRecord ( ) 






11 


Update Absolute from Linear Fixed EF beyond 


1 - No exception shall be thrown. 






Records 


2 - Shall throw 






1 - fid = EFLARU 


sim. access. SIMViewException with 






select 


reason code 






2 -recNumber = -1 


RECORD_NUMBER_NOT_AVAIL 






mode = REC_ACC_MODE_ABSOLUTE_CURRENT 










ABLE. 






recOffset = 








dataOffset = 


3 - Shall throw 






dataLength = 4 


sim. access. SIMViewException with 
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Id 


Description 


API Expectation 


APDU Expectation 




updateRecord ( ) 

2 - recNumber = 3 

updateRecord ( ) 


reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 
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Id 


Description 


API Expectation 


APDU Expectation 


12 


No current record in linear fixed EF, update 
current 

1 - fid = EFLARU 

select // No curr rec 

2 - recNumber =0 // curr rec 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = 
dataOffset = 
dataLength = 4 
updateRecord ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

Sim. access. SIMViewException with 

reason code 

RECORD NUMBER NOT AVAIL 

ABLE. 




13 


recOffset < 

1 - fid = EFLARU 
select 

2 - recNumber =1 // rec 1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = -1 
dataOffset = 
dataLength = 4 
updateRecord ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

OUT OF RECORD BOUNDARIE 

S. 




14 


recOffset + dataLength > Record Length 

1 - fid = EFLARU 
select ( ) 

2 - recNumber = 1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = 2 
dataOffset = 
dataLength = 4 
updateRecord 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

OUT OF RECORD BOUNDARIE 

S. 




15 


Updating with invalid mode 

1 - fid = EFLARU 
select ( ) 

2 - recNumber = 
mode = 1 
recOffset = 
dataOffset = 
dataLength = 4 
updateRecord ( ) 

3 - mode = 5 
updateRecord ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 
reason code INVALID MODE. 

3 - Shall throw 

sim. access. SIMViewException with 
reason code INVALID_MODE. 




16 


Updating Cyclic EF with invalid mode 

1 - fid = DFSIMTEST 
select ( ) 

2 - fid = EFCARU 
select ( ) 

3 - recNumber = 

mode = REC_ACC_MODE_NEXT 
recOffset = 
data[0:2] = '00' 
dataOffset = 
dataLength = 3 
updateRecord ( ) 

4 - recNumber = 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
updateRecord ( ) 

5 - recNumber = 2 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
updateRecord 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - Shall throw 

sim. access. SIMViewException with 
reason code INVALID_MODE. 

4 - Shall throw 

sim. access. SIMViewException with 
reason code INVALID_MODE. 

5 - Shall throw 

sim. access. SIMViewException with 
reason code INVALID_MODE. 




17 


data is null 

byte[] nullBuffer = null 
dataOffset = 
dataLength = 10 
updateRecord ( ) 


Shall throw 
java.lang.NullPointerException. 




18 


dataOffset < 

dataOffset = -1 
dataLength = 10 
updateRecord ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




19 


dataLength < 

dataOffset = 
dataLength = -1 
updateRecord ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




20 


dataOffset + dataLength > data.length 

dataOffset = 10 
dataLength = 11 
updateRecord ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




21 


EF is neither Cyclic nor Linear Fixed 


1 - No exception shall be thrown. 
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Id 


Description 


API Expectation 


APDU Expectation 




1 - fid = DFSIMTEST 
select 

2 - fid = EFTNR 
select 

3 - dataOffset = 
dataLength = 4 
updateRecord ( ) 


2 - No exception shall be thrown. 

3 - Shall throw 

Sim. access. SIMViewException with 
reason code 
FILEJNCONSISTENT. 




22 


Access condition not fulfilled 

1 - fid = EFCNU 
select 

2 - recOffset = 
dataOffset = 
dataLength = 1 

mode = REC_ACC_MODE_PREVIOUS 
updateRecord ( ) 

3 - fid = EFLNU 
select 

4 - recNumber = 1 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 
recOffset = 
dataOffset = 
dataLength = 1 
updateRecord ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIIVIViewException with 
reason code 
AC_NOT_FULFILLED. 

3 - No exception shall be thrown. 

4 - Shall throw 

sim. access. SIIVIViewException with 
reason code 
AC_NOT_FULFILLED. 
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EF is invalidated 

1 - fid = EFCNR 
invalidate ( ) 

2 - updateRecord ( ) 

3 - rehabilitate 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

INVALIDATION STATUS CONTR 

ADICTION. 

3 - No exception shall be thrown. 





6.1.1.8.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


2,3,4,5,7,8,10 


CRRN2 


2,3 


CRRN3 


5,6 


CRRN4 


7,8,9, 10 


CRRP1 


11 


CRRP2 


12 


CRRP3 


6 


CRRP4 


9 


CRRP5 


13 


CRRP6 


14 


CRRP7 


15 


CRRP8 


16 


CRRP9 


17 


CRRP10 


18 


CRRP11 


19 


CRRP12 


20 


CRRC1 


1 


CRRC2 


21 


CRRC3 


22 


CRRC4 


23 


CRRC5, CRRC6 


Not Tested 



6.1.1.9 Method seek 

Test Area Reference: API_1_SVW_SEEKB_BSS 

6.1.1.9.1 Conformance Requirements 

The method with the following header shall be compliant to its definition in the API. 

public short seek (byte mode, 

byte[] patt, 
short pattOffset, 
short pattLength) 
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throws Java. lang.NullPointerException, 

Java . lang . Array IndexOutOfBoundsExcept ion, 
SIMViewException 

Normal execution 

CRRNl: If the pattern in patt with the length pattLength at offset pattOffset is found in the record being specified by 
mode, the current record pointer is set to that record and the record number is returned. The record pointer of any 
other applet is not changed. This will be tested during the testing of the framework. 

CRRN2: If mode is SEEK_FROM_BEGINNING_FORWARD, the search starts with the first record forward 
towards the end of the file. 

CRRN3: If mode is SEEK_FROM_END_BACKWARD, the search starts with the last record backward towards the 
beginning of the file. 

CRRN4: If mode is SEEK_FROM_NEXT_FORWARD, the search starts from the next record after the current 
record pointer forward towards the end of file. If no current record pointer is selected, the search starts with the 
first record. 

CRRN5: If mode is SEEK_FROM_PREVIOUS_BACKWARD, the search starts from the previous record before 
the current record pointer backward towards the beginning of the file. If no current record pointer is selected the 
search starts with the last record. 

CRRN6: If pattern in patt is not found, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.PATTERN_NOT_FOUND. 

CRRN7: If mode is SEEK_FROM_NEXT_FORWARD and the record pointer is at the last record, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.PATTERN_NOT_FOUND. 

CRRN8: If mode is SEEK_FROM_PREVIOUS_BACKWARD and the record pointer is at the first record, an 
instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.PATTERN_NOT_FOUND. 

Parameter errors 

CRRPl: If mode is not between and 3 inclusive (0 = SEEK_FROM_BEGINNING_FORWARD, etc.), an instance 
of SIMViewException shall be thrown. The reason code shall be SIMViewException.INVALID_MODE. 

CRRP2: If the pattern array patt is null, an instance of NuUPointerException shall be thrown. 

CRRP3: If pattOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP4: If pattLength is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP5: If pattLength is greater than the size of the record of the currently selected EF, an instance of 
SIMViewException shall be thrown. The reason code shall be 
SIMViewException.OUT_OF_RECORD_BOUND ARIES. 

CRRP6: If pattOffset plus pattLength is greater than the length of the pattern array patt.length, an instance of 
ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: If the calling applet has currently no EF selected, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.NO_EF_SELECTED. 

CRRC2: If the currently selected EF is not linear fixed, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.FILEJNCONSISTENT. 

CRRC3: If the calling applet does not fulfil the access condition, READ, to perform this function, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException. AC_NOT_FULFILLED. 
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CRRC4: If the currently selected EF is invalidated and the file status of the EF does not allow for reading an 
invalidated file, an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.INVALIDATION_STATUS_CONTRADICTION. 

CRRC5: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC6: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.9.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 



Test Script: 
Test Applet: 
Load Script: 
Cleanup Script: 

6.1.1.9.3 



API_l_SVW_SEEKB_BSS_l.scr 
API_l_SVW_SEEKB_BSS_l.java 
API_l_SVW_SEEKB_BSS_l.ldr 
API_l_SVW_SEEKB_BSS_l.ldr 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


No EF selected 

Byte[] patt = new byte [20] 

pattOffset = 

pattLength = 10 

mode = SEEK_FROM_BEGINNING_FORWARD 

seekO 


Shall throw 

Sim. access. SIMViewException with 

reason code NO_EF_SELECTED. 




2 


Pattern not Found 

1 - fid = DFSIMTEST 
select ( ) 

2 - fid = EFLARU 
select 

3 - patt [0] = 'DA' 
pattOffset = 
pattLength = 1 

mode = SEEK_FROM_BEGINNING_FORWARD 
seek ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - Shall throw 

sim. access. SIMViewException with 

reason code 

PA! 1 bRN_NOT_FOUND. 




3 


Seek from Beginning Forward 

patt[0:2] = '55' 

pattOffset = 

pattLength = 3 

mode = SEEK_FROM_BEGINNING_FORWARD 

seek ( ) 


No exception shall be thrown. Shall 
return 1 




4 


Seek from End Backward 

patt[0:21 = '55' 

pattOffset = 

pattLength = 3 

mode = SEEK_FROM_END_BACKWARD 

seek ( ) 


No exception shall be thrown. Shall 
return 1 




5 


Seek from Next Forward 

patt [0:2] = 'AA' 

pattOffset = 

pattLength = 3 

mode = SEEK_FROM_NEXT_FORWARD 

seek ( ) 


No exception shall be thrown. Shall 
return 2 




6 


Last Record, Seek from Next Forward 

mode = SEEK_FROM_NEXT_FORWARD 
seekO 


Shall throw 

sim. access. SIMViewException with 

reason code 

PAI IbRN NOT FOUND. 




7 


Seek from Previous Backward 

patt[0:2] = '55' 

pattOffset = 

pattLength = 3 

mode = SEEK_FROM_PREVIOUS_BACKWARD 

seek ( ) 


No exception shall be thrown. Shall 
return 1 




8 


First Record, Seek from Previous Backward 


Shall throw 
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Id 


Description 


API Expectation 


APDU Expectation 




SEEK_FROM_PREVIOUS_BACKWARD 
seekO 


Sim. access. SIMViewException with 

reason code 

PA! IbRN NOT FOUND. 




9 


Pattern not Found (out of reach) 

patt[0:2] = '55' 

pattOffset = 

pattLength = 3 

mode = SEEK_FROM_NEXT_FORWARD 

seekO 


Shall throw 

sim. access. SIIVIViewException with 

reason code 

PA! 1 bRN_NOT_FOUND. 




10 


Invalid mode 

1 - mode = 4 
seek ( ) 

2 - mode = -1 
seek ( ) 


1 - Shall throw 

sim. access. SIIVIViewException with 
reason code INVALID IVIODE 

2 - Shall throw 

sim. access. SIIVIViewException with 
reason code INVALID MODE 




11 


patt is null 

byte[] nullBuffer = null 

mode = SEEK_FROM_BEGINNING_FORWARD 

seek 


Shall throw 
java.lang.NullPointerException. 




12 


pattOffset < 

patt[0:2] = '55' 

pattOffset = -1 

pattLength = 3 

mode = SEEK_FROM_BEGINNING_FORWARD 

seekO 


Shall throw 

java.lang. 

Array IndexOutOfBoundsException 




13 


pattLength < 

patt[0:2] = '55' 

pattOffset = 

pattLength = -1 

mode = SEEK_FROM_BEGINNING_FORWARD 

seekO 


Shall throw 

java.lang. 

Array IndexOutOfBoundsException 




14 


pattLength > size of record 

patt[0:4] = '55' 

pattOffset = 

pattLength = 4 

mode = SEEK_FROM_BEGINNING_FORWARD 

seekO 


Shall throw 

sim. access. SIMViewException with 

reason code 

OUT OF RECORD BOUNDARIE 

S 




15 


pattOffset + pattLength > patt.length 

patt[0:2] = '55' 

pattOffset = 1 

pattLength = 3 

mode = SEEK_FROM_BEGINNING_FORWARD 

seekO 


Shall throw 

java.lang. 

Array IndexOutOfBoundsException 




16 


EF is not Linear Fixed 

1 - fid = EFTNU 
select 

2 - pattOffset = 
pattLength = 3 

mode = SEEK_FROM_BEGINNING_FORWARD 
seek ( ) 

3 - fid = EFCNU 
select ( ) 

seek ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 
reason code 
FILEJNCONSISTENT 

3 - Shall throw 

sim. access. SIMViewException with 

reason code 

FILE INCONSISTENT 




17 


Access condition not fulfilled 

1 - fid = EFLNR 
select 

2 - patt [0] = '55' 
pattOffset = 
pattLength = 1 

mode = SEEK„FROM_BEGINNING_FORWARD 
seek ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 
reason code 
AC_NOT_FULFILLED. 




18 


EF is invalidated 

1 - fid = EFLARU 
select 

2 - invalidate () 

3 - patt [0] = '55 
pattOffset = 
pattLength = 1 

mode = SEEK_FROM_BEGINNING_FORWARD 
seek ( ) 

4 - rehabilitate 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - Shall throw 

sim. access. SIMViewException with 

reason code 

INVALIDATION STATUS CONTR 

ADICTION. 

4 - No exception shall be thrown. 
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6.1.1.9.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


2,3-6,7 


CRRN2 


3 


CRRN3 


4 


CRRN4 


5 


CRRN5 


7 


CRRN6 


2, 6, 8, 9 


CRRN7 


6 


CRRN8 


8 


CRRP1 


10 


CRRP2 


11 


CRRP3 


12 


CRRP4 


13 


CRRP5 


14 


CRRP6 


15 


CRRC1 


1 


CRRC2 


16 


CRRC3 


17 


CRRC4 


18 


CRRC5, CRRC6 


Not Tested 



6.1.1.10 Method increase 



Test Area Reference: API_1_SVW_INCR_BS_BS 



6.1.1.10.1 



Conformance Requirements 



The method with the following header shall be compliant to its definition in the API. 

public short increase (byte [ ] incr, 

short incrOffset, 
byte [ ] resp, 
short respOffset) 
throws Java . lang.NullPointerException, 

Java . lang, ArraylndexOutOfBoundsException, 
SIMViewException 



Normal execution 



CRRNl: The value in the array incr is added to the value of the last increased / updated record in the currently 
selected cyclic EF. The result is stored in the oldest record and returned in the array resp. The updated record 
becomes record number 1 and is selected as current record. The number of bytes of valid data in resp is returned. 

Parameter errors 

CRRPl: If the array incr is null, an instance of NullPointerException shall be thrown. 

CRRP2: If incrOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: If incrOffset plus the value 3, is greater than the length of the array incr.length, an instance of 
ArraylndexOutOfBoundsException shall be thrown. 

CRRP4: If the result of the addition is greater than the maximum value of the record (represented by all bytes set to 
'FF'), an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.MAX_VALUE_REACHED. 

CRRP5: If the array resp is null, an instance of NullPointerException shall be thrown. 

CRRP6: If respOffset is less than 0, an instance of ArraylndexOutOfBoundsException shall be thrown. 

CRRP7: If the remaining length of the array resp at the offset respOffset is less than the length of the record, an 
instance of ArraylndexOutOfBoundsException shall be thrown. 
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Context errors 

CRRC 1 : If the calling applet has currently no EF selected, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.NO_EF_SELECTED. 

CRRC2: If the currently selected EF is not cyclic, an instance of SIMViewException shall be thrown. The reason 
code shall be SIMViewException.FILE_INCONSISTENT. 

CRRC3: If increase is not allowed as indicated by the FCIbyte 8 (GSM 11.11: FCI structure of an EF returned by 
the SELECT command), an instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.FILE_INCONSISTENT. 

CRRC4: If the calling applet does not fulfil the access condition, INCREASE, to perform this function, an instance 
of SIMViewException shall be thrown. The reason code shall be SIMViewException. AC_NOT_FULFILLED. 

CRRC5: If the currently selected EF is invalidated, an instance of SIMViewException shall be thrown. The reason 
code shall be SIMViewException.INVALIDATION_STATUS_CONTRADICTION. 

CRRC6: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC7: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.10.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 

Test Script: API_l_SVW_INCR_BS_BS_l.scr 

Test Applet: API_l_SVW_INCR_BS_BS_l.java 

Load Script: API_l_SVW_INCR_BS_BS_l.ldr 

Cleanup Script: API_l_SVW_INCR_BS_BS_l.clr 



6.1.1.10.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


No EF selected 

byte[] incr = new byte [4] 
byte[] resp = new byte [4] 
incrOffset = 
respOffset = 
increase ( ) 


Shall throw 

sim. access. SIIVIViewException with 

reason code NO_EF_SELECTED. 




2 


Increase , verify response 

1 - fid = DFSIMTEST 
select ( ) 

2 - fid = EFCARU 
select ( ) 

3 - //Set both records to 00 00 00 
mode = REC_ACC_MODE_PREVIOUS 

data [0:3] = 
dataOffset = 
dataLength = 3 
updateRecord ( ) 
updateRecord ( ) 

4 - incrOffset = 
incr[2] = 1 
respOffset = 
increase ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown. 
resp[] shall contain {0,0,1 ,0}. 




3 


Increase, verify file 

1 - incrOffset = 1 
incr[2] = 0, incr[3] = 2 
respOffset = 1 
increase ( ) 

2 - resp[3] = 
recNumber = 

mode = REC_ACC_MODE_ABSOLUTE_CURRENT 


1 - No exception shall be thrown. 
respG shall contain {0,0,0,3}. 

2 - No exception shall be thrown. 
respG shall contain {0,0,3,0}. 
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Id 


Description 


API Expectation 


APDU Expectation 




recOffset = 
respOffset = 
respLength = 
readRecord ( ) 






4 


incr is null 

byte[] nullBuffer = null 
incrOffset = 
respOffset = 
increase ( ) 


Shall throw 
java.lang.NullPointerException. 




5 


incrOffset < 

incrOffset = -1 
respOffset = 
increase ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




6 


incrOffset + 3 > incr.length 

incrOffset = 2 
respOffset = 
increase ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




7 


Reach Maximum Value 

incr[0] = incr[l] = incr[2] = ' FF ' 
incrOffset = 
respOffset = 
increase ( ) 


Shall throw 

Sim. access. SIMViewException with 

reason code 

MAX_VALUE_REACHED. 




8 


resp is null 

incr[0] = incr[l] = 0x00' 

incr[2] = '02' 

incrOffset = 

byte[] respNull = null 

respOffset = 

increase ( ) 


Shall throw 
Java.lang.NullPointerException. 




9 


respOffset < 

incrOffset = 
respOffset = -1 
increase ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




10 


respOffset + recordLength > resp.length 

incrOffset = 
respOffset = 2 
increase ( ) 


Shall throw 

java.lang. 

ArraylndexOutOfBoundsException. 




11 


EF is not Cyclic 

1 - fid = EFTARU 
select ( ) 

2 - incrOffset = 
respOffset = 
increase ( ) 

3 - fid = EFLARU 
select 

4 - incrOffset = 
respOffset = 
increase ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

Sim. access. SIIVIViewException with 
reason code 
FILEJNCONSISTENT. 

3 - No exception shall be thrown. 

4 - Shall throw 

sim. access. SIMViewException with 

reason code 

FILE INCONSISTENT. 




12 


Access condition not fulfilled 

1 - fid = EFCNIC 
select 

2 - incrOffset = 
respOffset = 
increase ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIIVIViewException with 
reason code 
AC_NOT_FULFILLED. 




13 


EF is invalidated 

1 - fid = EFCARU 
select 

2 - invalidate () 

3 - incrOffset = 
respOffset = 
increase ( ) 

4 - rehabilitate 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - Shall throw 

sim. access. SIMViewException with 

reason code 

INVALIDATION STATUS CONTR 

ADIGTION. 

4 - No exception shall be thrown. 




14 


Check increase not allowed from FCI 

1 - fciOffset = 
fciLength = 8 

select (FID_EF_CINA, fci...) 
Verify FCI byte 8 (fci [7]) 

2 - incrOffset = 
respOffset = 
increase () 


1 - No exception shall be thrown. 
Bit 7 of resp[7] shall not be set (0), 
indicating that increase is not 
allowed. 

2 - Shall throw 

sim. access. SIMViewException with 
reason code 
FILEJNCONSISTENT 
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6.1.1.10.4 



Test Coverage 



CRR Number 


Test Case Number 


CRRN1 


2,3 


CRRP1 


4 


CRRP2 


5 


CRRP3 


6 


CRRP4 


7 


CRRP5 


8 


CRRP6 


9 


CRRP7 


10 


CRRC1 


1 


CRRC2 


11 


CRRC3 


14 


CRRC4 


12 


CRRC5 


13 


CRRC6, CRRC7 


Not Tested 



6.1.1.11 Method invalidate 

Test Area Reference: API_1_SVW_INVL 

6.1 .1 .1 1 .1 Conformance Requirements 

The method with the following header shall be compliant to its definition in the API. 

public void invalidate ( ) 

throws SIMViewException 

Normal execution 

CRRNl: The currently selected EF of the calling applet shall be invalidated, i.e. the flag in the EF file status shall be 
changed accordingly. 

Parameter errors 

This method has no parameters. 

Context errors 

CRRCl: If the calling applet has currently no EF selected, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.NO_EF_SELECTED. 

CRRC2: If the calling applet does not fulfil the access condition, INVALIDATE, to perform this function, an 
instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.AC_NOT_FULFILLED. 

CRRC3: If the currently selected EF is already invalidated, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.INVALIDATION_STATUS_CONTRADICTION. 

CRRC4: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC5: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.11.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 
Test Script: API_l_SVW_INVL_l.scr 

Test Applet: API_l_SVW_INVL_l.java 
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Load Script: 
Cleanup Script: 

6.1.1.11.3 



API_1_S VW_INVL_1 .Idr 
API_1_S VW_IN VL_1 .clr 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


No EF is selected 

1 - invalidate () 


1 - Shall throw 

Sim. access. SIMViewException with 

reason code NO EF SELECTED. 




2 


Invalidate EF 

1 - fid = DFSIMTEST 
select ( ) 

2 - fid = EFTNR 
select ( ) 

3 - invalidate ( ) 

4 - rehabilitate 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown. 




3 


Access condition not fulfilled 

1 - fid = EFCNIV 
select ( ) 

2 - invalidate ( ) 


1 - No exception shall be thrown. 

2 - Shall throw 

Sim. access. SIIVIViewException with 

reason code 

AC NOT FULFILLED. 




4 


EF is already invalidated 

1 - fid = EFTNR 
select ( ) 

2 - invalidate ( ) 

3 - invalidate () 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - Shall throw 

sim. access. SIIVIViewException with 

reason code 

INVALIDATION STATUS CONTR 

ADICTION. 





6.1.1.11.4 



Test Coverage 



CRR number 


Test Case Number 


CRRN1 


2 


CRRC1 


1 


CRRC2 


3 


CRRC3 


4 


CRRC4, CRRC5 


Not Tested 



6.1.1.12 Method rehabilitate 

Test Area Reference: API_1_SVW_REHA 

6.1.1.12.1 Conformance Requirements 

The method with the following header shall be compliant to its definition in the API. 

public void rehabilitate ( ) 

throws SIMViewException 

Normal execution 

CRRNl: The currently selected EF of the calling applet shall be rehabilitated, i.e. the flag in the EF file status shall 
be changed accordingly. 

Parameter errors 

This method has no parameters. 

Context errors 

CRRCl: If the calling applet has currently no EF selected, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.NO_EF_SELECTED. 
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CRRC2: If the calling applet does not fulfil the access condition, REHABILITATE, to perform this function, an 
instance of SIMViewException shall be thrown. The reason code shall be 
SIMViewException.AC_NOT_FULFILLED. 

CRRC3: If the currently selected EF is not invalidated, an instance of SIMViewException shall be thrown. The 
reason code shall be SIMViewException.INVALIDATION_STATUS_CONTRADICTION. 

CRRC4: If the method call causes a memory problem (e.g. memory access error), an instance of SIMViewException 
shall be thrown. The reason code shall be SIMViewException.MEMORY_PROBLEM. 

CRRC5: If the method call causes an error to occur that is not expected and thus not handled, an instance of 
SIMViewException shall be thrown. The reason code shall be SIMViewException.INTERNAL_ERROR. 

6.1.1.12.2 Test Suite Files 

Additional requirements for the GSM personalisation: None 

Test Script: API_l_SVW_REHA_l.scr 

Test Applet: API_l_SVW_REHA_l.java 

Load Script: API_l_SVW_REHA_Lldr 

Cleanup Script: API_l_SVW_REHA_Lclr 



6.1.1.12.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 





SIM Initialisation 


Responses ignored. 




1 


No EF is selected 

1 - rehabilitate 


1 - Shall throw 

Sim. access. SIIVIViewException with 

reason code NO EF SELECTED. 




2 


Rehabilitate invalidated File 

1 - fid = DFSIMTEST 
select ( ) 

2 - fid = EFCNR 
select ( ) 

3 - invalidate 

4 - rehabilitate 

5 - byte[] incr = new byte[3] = {0,0,1} 
incrOffset = 

byte[] resp = new byte[l] = 1 
respOffset = 
increase ( ) 


1 - No exception shall be thrown. 

2 - No exception shall be thrown. 

3 - No exception shall be thrown. 

4 - No exception shall be thrown. 

5 - No exception shall be thrown. 
resp[] shall contain {0,0,1}. 




3 


Access condition not fulfilled 

1 - fid = EFCNRH 
select 

2 - rehabilitate 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

AC NOT FULFILLED.. 




4 


Rehabilitate validated File 

1 - fid = EFCNR 
select 

2 - rehabilitate 


1 - No exception shall be thrown. 

2 - Shall throw 

sim. access. SIMViewException with 

reason code 

INVALIDATION STATUS CONTR 

ADICTION. 





6.1.1.12.4 



Test Coverage 



CRR number 


Test Case Number 


CRRN1 


2 


CRRC1 


1 


CRRC2 


3 


CRRC3 


4 


CRRC5, CRRC6 


Not Tested 
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6.1.2 Class SIMSystem 

6.1 .2.1 Method getTheSIMView 

Test Area Reference: API_1_SSY_GETS 

6.1.2.1.1 Conformance Requirement: 

The method with following header shall compliant to its definition in the API. 

public static SIMView getTheSIMView ( ) 

Normal execution 

CRRNl: returns a reference to class which implements the SIMView interface 

Parameters error 
No requirements 

Context errors 
No requirements 

6.1.2.1.2 Test suite files 

No additional requirements for the GSM personalisation: 
Test Script: API_l_SSY_GETS_l.scr 

Test Applet: API_l_SSY_GETS_l.java 

Installation parameter: API_l_SSY_GETS.install (Same as default applet) 

Load Script: API_l_SSY_GETS.ldr 

6.1.2.1.3 Test Procedure 



ETSI TS 101 955 V7.1.0 (2001-06) 



Id 


Description 


API Expectation 


APDU Expectation 


1 


reference not equal null after execute 


The returned reference shall be not 
null after execute 




2 


reference to the GSM interface 


Returned a reference to the GSM 
interface 





6.1.2.1.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2 



6.1 .3 Class SIMViewException 

6.1.3.1 Method throwit 

Test Area Reference: API_1_SVE_THITS 

6.1.3.1.1 Conformance Requirement: 

The method with following header shall compliant to its definition in the API. 
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public static void throwit (short reason) 
throws SIMViewException 
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Normal execution 

CRRNl: Throws the JCRE instance of SIMViewException with the specified reason 
CRRN2: extends Java card.framework.CardRuntimeException 

Parameters error 
No requirements 

Context errors 
No requirements 

6.1.3.1.2 Test suite files 

No additional requirements for the GSM personalisation 

Test Script: API_l_SVE_THITS_l.scr 

Test Applet: API_1_SVE_THITS_1 .Java 

Installation parameter: API_1_SVE_THITS. install (Same as default applet ) 

Load Script: API_l_SVE_THITS.ldr 

6.1.3.1.3 Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Throws the JCRE instance of 
SIMViewException with the specified reason 


Reason (specified) 




2 


SIMViewException extends 
javacard.framework.CardRuntimeException 


Reason (specified) 





6.1.3.1.4 



Test Coverage 



CRR number 


Test case number 


N1 


1 


N2 


2 



6.1.3.2 Constructor 

Test Area Reference: API_l_SVE_COORS 

6.1.3.2.1 Conformance Requirement: 

The method with following header shall compliant to its definition in the API. 

public SIMViewException (short reason) 
throws SIMViewException 

Normal execution 

CRRNl: Construct a SIMViewException with the specified reason 

Parameters error 
No requirements 
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Context errors 
No requirements 

6.1.3.2.2 Test suite files 

No additional requirements for the GSM personalisation 

Test Script: APl_l_SVE_COORS_l.scr 

Test Applet: API_l_SVE_COORS_l.java 

Installation parameter: API_l_SVE_COORS. install (Same as default applet ) 

Load Script: API_l_SVE_COORS.ldr 

6.1.3.2.3 Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


SIMViewException with the specified reason 

(The reason shall set with setReason and 
compare the Exception with getReason) 


Reason (specified) 





6.1.3.2.4 



Test Coverage 



CRR number 


Test case number 


N1 


1 



6.1.3.3 Reason Codes 

Test Area Reference: API_l_SVE_CONS 

6.1.3.3.1 Conformance Requirement: 

There is no API, only constants. This constants shall compliant to its definition in the API. 

Normal execution 

CRRN 1 : The Constants of the class SIMViewException shall all have the same name and value defined in the 
GSM03.19 

CRRN2: Constructs SIMViewException a Exception with the specified reason 

Parameters error 
None 

Context errors 
None 

6.1.3.3.2 Test suite files 

Additional requirements for the GSM personalisation: None 
Test Script: API_l_SVE_CONS_l.scr 

Test Applet: API_l_SVE_CONS_l.java 

Installation parameter: API_l_SVE_CONS. install 

Same as default applet 
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Load Script: 



6.1.3.3.3 



API_l_SVE_CONS.ldr 



Test Procedure 



Id 


Description 


01 


Check 


constant 


NO_EF_SELECTED = 1; 




02 


Check 


constant 


FILE_INCONSISTENT = 2 




03 


Check 


constant 


AC_NOT_FULFILLED = 3 




04 


Check 


constant 


FILE_NOT_FOUND = 4 




05 


Check 


constant 


INTERNAL_ERROR = 5 




06 


Check 


constant 


INVALIDATION_STATUS_CONTRADICTION = 


= 6 


07 


Check 


constant 


OUT_OF_FILE_BOUNDARIES = 7 




08 


Check 


constant 


OUT_OF_RECORD_BOUNDARIES = 8 




09 


Check 


constant 


RECORD_NUMBER_NOT_AVAILABLE = 9 




10 


Check 


constant 


INVALID_MODE = 10 




11 


Check 


constant 


PATTERN_NOT_FOUND =11 




12 


Check 


constant 


MAX_VALUE_REACHED = 12 




13 


Check 


constant 


MEMORY_PROBLEM =13 





6.1.3.3.4 



Test Coverage 



CRR number 


Test case number 


N1 


1-13 


N2 


1-13 



6.2 

6.2.1 



Package sim.toolkit 
Interface ToolkitConstants 



6.2.1.1 Constants 

Test Area Reference: API_2_TKC_CONS 

6.2.1.1.1 Conformance Requirement: 

There is no API, only constants. This constants shall be compare to its definition in the API. 

Normal execution 

CRRNl: The Toolkit Constants shall all have the same name and value defined in the GSM03.19 normalization. 

Parameters error 
None 

Context errors 
None 

6.2.1.1.2 Test suite files 

No additional requirements for the GSM personalisation. 
Test Script: API_2_TKC_CONS_l.scr 

Test case trigger: 1- first applet check the first 80 constants 

2- second applet checked the 66 others. 
Test Applet: API_2_TKC_CONS_l.java 
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Load Script: 
Cleaning script: 

6.2.1.1.3 

First applet triggered: 



API_2_TKC_CONS_l .Idr 
API_2_TKC_CONS_l .clr 



Test Procedure 



Test Case 


Id 


Test purpose 


01 


Check 


constant 


EVENT_PROF I LE_DOWNLOAD= 1 




02 


Check 


constant 


EVENT_F0RMATTED_SMS_PP_ENV=2 




03 


Check 


constant 


EVENT_F0RMATTED_SMS_PP_UPD=3 




04 


Check 


constant 


EVENT_UNF0RMATTED_SMS_PP_ENV=4 




05 


Check 


constant 


EVENT_UNF0RMATTED_SMS_PP_UPD=5 




06 


Check 


constant 


EVENT_UNF0RMATTED_SMS_CB=6 




07 


Check 


constant 


EVENT_MENU_SELECTI0N=7 




08 


Check 


constant 


EVENT_MENU_SELECTI0N_HELP_REQUEST=8 




09 


Check 


constant 


EVENT_CALL_C0NTR0L_BY_SIM=9 




10 


Check 


constant 


EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM=10 




11 


Check 


constant 


EVENT_TIMER_EXPIRATI0N=11 




12 


Check 


constant 


EVENT_EVENT_D0WNL0AD_MT_CALL12 




13 


Check 


constant 


EVENT_EVENT_D0WNL0AD_CALL_C0NNECTED=13 




14 


Check 


constant 


EVENT_EVENT_D0WNL0AD_CALL_DISC0NNECTED=14 




15 


Check 


constant 


EVENT_EVENT_D0WNL0AD_L0CATI0N_STATUS = 15 




16 


Check 


constant 


EVENT_EVENT_D0WNL0AD_USER_ACTIVITY=16 




17 


Check 


constant 


EVENT_EVENT_DOWNLOAD_IDLE_SCREEN_AVAILABLE= 


17 


18 


Check 


constant 


EVENT_EVENT_D0WNL0AD_CARD_READER_STATUS=18 




19 


Check 


constant 


EVENT_STATUS_COMMAND=127 




20 


Check 


constant 


EVENT_UNREC0GNIZED_ENVEL0PE=-1 




21 


Check 


constant 


BTAG_PROACTIVE_SIM_COMMAND='D0 ' 




22 


Check 


constant 


BTAG_SMS_PP_DOWNWLOAD= ' Dl ' 




23 


Check 


constant 


BTAG_CELL_BROADCAST_DOWNLOAD= ' D2 ' 




24 


Check 


constant 


BTAG_MENU_SELECTION= ' D3 ' 




25 


Check 


constant 


BTAG_CALL_CONTROL= ' D4 ' 




26 


Check 


constant 


BTAG_MO_SHORT_MESSAGE_CONTROL= ' D5 ' 




27 


Check 


constant 


BTAG_EVENT_DOWNLOAD= ' D6 ' 




28 


Check 


constant 


BTAG_TIMER_EXPIRATI0N='D7 ' 




29 


Check 


constant 


TAG_COMMAND_DETAILS= ' 01 ' 




30 


Check 


constant 


TAG_DEVICE_IDENTITIES= ' 02 ' 




31 


Check 


constant 


TAG_RESULT='03' 




32 


Check 


constant 


TAG_DURATION='04' 




33 


Check 


constant 


TAG_ALPHA_IDENTIFIER= ' 05 ' 




34 


Check 


constant 


TAG_ADDRESS='06' 




35 


Check 


constant 


TAG_CAPABILITY_CONFIGURATION_PARAMETERS= ' 07 


' 


36 


Check 


constant 


TAG_CALLED_PARTY_SUBADDRESS= ' 08 ' 




37 


Check 


constant 


TAG_SS_STRING= ' 09 ' 




38 


Check 


constant 


TAG_USSD_STRING= ' OA ' 




39 


Check 


constant 


TAG_SMS_TPDU= ' OB ' 




40 


Check 


constant 


TAG_CELL_BROADCAST_PAGE= ' OC ' 




41 


Check 


constant 


TAG_TEXT_STRING= ' OD ' 




42 


Check 


constant 


TAG_TONE= ' OE ' 




43 


Check 


constant 


TAG_ITEM='OF' 




44 


Check 


constant 


TAG_ITEM_IDENTIFIER= ' 10 ' 




45 


Check 


constant 


TAG_RESPONSE_LENGTH=' 11 ' 




46 


Check 


constant 


TAG_FILE_LIST= ' 12 ' 




47 


Check 


constant 


TAG_LOCATION_INFORMATION= ' 13 ' 




48 


Check 


constant 


TAG_IMEI='14' 




49 


Check 


constant 


TAG_HELP_REQUEST= ' 15 ' 




50 


Check 


constant 


TAG_NETWORK_MEASUREMENT_RESULTS= ' 16 ' 




51 


Check 


constant 


TAG_DEFAULT_TEXT= ' 17 ' 




52 


Check 


constant 


TAG_ITEMS_NEXT_ACTION_INDICATOR=' 18 ' 




53 


Check 


constant 


TAG_EVENT_LIST='19' 




54 


Check 


constant 


TAG_CAUSE='1A' 




55 


Check 


constant 


TAG_LOCATION_STATUS= ' IB ' 
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56 


Check 


constant 


TAG_TRANSACTION_IDENTIFIER= ' IC ' 




57 


Check 


constant 


TAG_BCCH_CHANNEL_LIST= ' ID ' 




58 


Check 


constant 


TAG_ICON_IDENTIFIER= ' IE ' 




59 


Check 


constant 


TAG_ITEM_ICON_IDENTIFIER_LIST= ' IF ' 




60 


Check 


constant 


TAG_CARD_READER_STATUS= ' 20 ' 




61 


Check 


constant 


TAG_CARD_ATR= '21' 




62 


Check 


constant 


TAG_C_APDU='22' 




63 


Check 


constant 


TAG_R_APDU='23' 




64 


Check 


constant 


TAG_TIMER_IDENTIFIER= ' 24 ' 




65 


Check 


constant 


TAG_TIMER_VALUE= ' 25 ' 




66 


Check 


constant 


TAG_DATE_TIME_AND_TIME_ZONE= ' 26 ' 




67 


Check 


constant 


TAG_CALL_CONTROL_REQUESTED_ACTION= 


'27' 


68 


Check 


constant 


TAG_AT_COMMAND= ' 28 ' 




69 


Check 


constant 


TAG_AT_RESPONSE= '29' 




70 


Check 


constant 


TAG_BC_REPEAT_INDICAT0R='2A' 




71 


Check 


constant 


TAG_IMMEDIATE_RESPONSE= ' 2B ' 




72 


Check 


constant 


TAG_DTMF_STRING= ' 2C ' 




73 


Check 


constant 


TAG_SET_CR='80' 




74 


Check 


constant 


TAG_SET_NO_CR= ' 7F ' 




75 


Check 


constant 


TLV_LENGTH_CODED_2BYTES='81' 




76 


Check 


constant 


TLV_NOT_FOUND= ' 00 ' 




77 


Check 


constant 


TLV_FOUND_CR_SET= ' 01 ' 




78 


Check 


constant 


TLV_FOUND_CR_NOT_SET= ' 02 ' 




79 


Check 


constant 


PRO_CMD_REFRESH= ' 01 ' 




80 


Check 


constant 


PRO_CMD_MORE_TIME= ' 02 ' 





Second applet triggered: 



Test Case 


Id 


Test purpose 


01 


Check 


constant 


PRO_CMD_SET_UP_CALL= ' 10 ' 


02 


Check 


constant 


PRO_CMD_SEND_SS= ' 11 ' 


03 


Check 


constant 


PRO_CMD_SEND_USSD= ' 12 ' 


04 


Check 


constant 


PRO_CMD_SEND_SHORT_MESSAGE= ' 13 ' 


05 


Check 


constant 


PRO_CMD_SEND_DTMF= ' 14 ' 


06 


Check 


constant 


PRO_CMD_PLAY_TONE= '20' 


07 


Check 


constant 


PR0_CMD_DISPLAY_TEXT='21' 


08 


Check 


constant 


PRO_CMD_GET_INKEY= ' 22 ' 


09 


Check 


constant 


PRO_CMD_GET_INPUT= '23' 


10 


Check 


constant 


PRO_CMD_SELECT_ITEM='24' 


11 


Check 


constant 


PRO_CMD_PROVIDE_LOCAL_INFORMATION= '26' 


12 


Check 


constant 


PRO_CMD_TIMER_MANAGEMENT= ' 27 ' 


13 


Check 


constant 


PRO_CMD_SET_UP_IDLE_MODE_TEXT= ' 28 ' 


14 


Check 


constant 


PRO_CMD_PERFORM_CARD_APDU= ' 30 ' 


15 


Check 


constant 


PRO_CMD_POWER_ON_CARD= ' 31 ' 


16 


Check 


constant 


PRO_CMD_POWER_OFF_CARD= ' 32 ' 


17 


Check 


constant 


PRO_CMD_GET_READER_STATUS= ' 33 ' 


18 


Check 


constant 


PRO_CMD_RUN_AT_COMMAND= ' 34 ' 


19 


Check 


constant 


DEV_ID_KEYPAD= ' 01 ' 


20 


Check 


constant 


DEV_ID_DISPLAY= ' 02 ' 


21 


Check 


constant 


DEV_ID_EARPIECE= ' 03 ' 


22 


Check 


constant 


DEV_ID_ADDITIONAL_CARD_READER_0= ' 10 ' 


23 


Check 


constant 


DEV_ID_ADDITI0NAL_CARD_READER_1= ' 11 ' 


24 


Check 


constant 


DEV_ID_ADDITI0NAL_CARD_READER_2= ' 12 ' 


25 


Check 


constant 


DEV_ID_ADDITI0NAL_CARD_READER_3= ' 13 ' 


26 


Check 


constant 


DEV_ID_ADDITI0NAL_CARD_READER_4= ' 14 ' 


27 


Check 


constant 


DEV_ID_ADDITI0NAL_CARD_READER_5= ' 15 ' 


28 


Check 


constant 


DEV_ID_ADDITI0NAL_CARD_READER_6= '16' 


29 


Check 


constant 


DEV_ID_ADDITI0NAL_CARD_READER_7= ' 17 ' 


30 


Check 


constant 


DEV_ID_SIM='81' 


31 


Check 


constant 


DEV_ID_ME='82' 


32 


Check 


constant 


DEV_ID_NETWORK= ' 83 ' 


33 


Check 


constant 


DCS_DEFAULT_ALPHABET= ' 00 ' 


34 


Check 


constant 


DCS_8_BIT_DATA='04' 
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35 


Check 


constant 


DCS_UCS2='08' 


36 


Check 


constant 


SW1_RP_ERR0R= ' 9E ' 


37 


Check 


constant 


SW1_RP_ACK= ' 9F ' 


38 


Check 


constant 


POLL_NO_DURATION=0 


39 


Check 


constant 


POLL_SYSTEM_DURATION= (-1) 


40 


Check 


constant 


RES_CMD_PERF='00' 


41 


Check 


constant 


RES_CMD_PERF_PARTIAL_COMPR= ' 01 ' 


42 


Check 


constant 


RES_CMD_PERF_MISSING_INFO= ' 02 ' 


43 


Check 


constant 


RES_CMD_PERF_REFRESH_ADD_EF_READ= ' 03 ' 


44 


Check 


constant 


RES_CMD_PERF_REQ_ICON_NOT_DISP= ' 04 ' 


45 


Check 


constant 


RES_CMD_PERF_MODIF_CC_SIM= ' 05 ' 


46 


Check 


constant 


RES_CMD_PERF_SESSION_TERM_USER= ' 10 ' 


47 


Check 


constant 


RES_CMD_PERF_BACKWARD_MOVE_REQ= ' 11 ' 


48 


Check 


constant 


RES_CMD_PERF_NO_RESP_FROM_USER= ' 12 ' 


49 


Check 


constant 


RES_CMD_PERF_HELP_INFO_REQ= ' 13 ' 


50 


Check 


constant 


RES_CMD_PERF_USSD_TRANSAC_TERM= ' 14 ' 


51 


Check 


constant 


RES_TEMP_PB_ME_UNABLE_PROC= ' 20 ' 


52 


Check 


constant 


RES_TEMP_PB_SESSION_TERM_USER= ' 21 ' 


53 


Check 


constant 


RES_TEMP_PB_USER_REJECT_CALL_REQ= ' 22 ' 


54 


Check 


constant 


RES_TEMP_PB_USER_CLEAR_CALL= ' 23 ' 


55 


Check 


constant 


RES_TEMP_PB_IN_CONTR_TIMER_STATE= ' 24 ' 


56 


Check 


constant 


RES_TEMP_PB_INTERACT_CC_BY_SIM= ' 25 ' 


57 


Check 


constant 


RES_ERROR_CMD_BEYOND_ME_CAPAB= ' 30 ' 


58 


Check 


constant 


RES_ERROR_CMD_TYP_NOT_UNDERSTOOD= ' 31 ' 


59 


Check 


constant 


RES_ERROR_CMD_DATA_NOT_UNDERSTOOD= ' 32 ' 


60 


Check 


constant 


RES_ERROR_CMD_NUMBER_NOT_KNOWN= ' 33 ' 


61 


Check 


constant 


RES_ERROR_SS_RETURN_ERROR= ' 34 ' 


62 


Check 


constant 


RES_ERROR_SMS_RP_ERROR= ' 35 ' 


63 


Check 


constant 


RES_ERROR_REQ_VALUES_MISS= ' 36 ' 


64 


Check 


constant 


RES_ERROR_USSD_RETURN_ERROR= ' 37 ' 


65 


Check 


constant 


RES_ERROR_MULTIPLE_CARD_ERROR= ' 38 ' 


66 


Check 


constant 


RES_ERROR_INTERACT_CC_SMSMO_BY_SIM= ' 39 ' 



We expect for each case the comparison is true 
6.2.1.1.4 Test Coverage 



CRR number 


Test case number 


1 


each case of the two 
applets 



6.2.2 Interface Toolkitlnterface 
6.2.2.1 Method processToolkit 

Test Area Reference: API_1_PRTKB 

6.2.2.1.1 Conformance Requirement: 

The method with following prototype shall compliant to its definition in the API. 

public void processToolkit (byte event) 
throws ToolkitException 

Normal execution 

CRRNl: This interface must be implemented by a Toolkit applet (which extends the javacard.framework. Applet 
class) so that it can be triggered by the Toolkit Handler according to the registration information. 

CRRN2: The Toolkit applet will have to implement the processToolkit shared method so that the following events 
can be notified; 
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Event 


Description 


EVENT_PROFILE_DOWNLOAD 


Terminal Profile command reception 


EVENT_FORMATTED_SMS_PP_ENV 


03.48 formatted envelope SMS-PP Data 
Download reception 


EVENT_FORMATTED_SMS_PP_UPD 


03.48 formatted Update Record EF SMS 


EVENT_UNFORMATTED_SMS_PP_ENV 


Unformatted Envelope SIVIS-PP Data Download 
reception 


EVENT_UNFORMATTED_SMS_PP_UPD 


Unformatted Update Record EF SMS 


EVENT_UNFORMATTED_SMS_CB 


Unformatted Cell Broadcast Data Download 
command reception 


EVENT_MENU_SELECTION 


Envelope Menu Selection command reception 


EVENT_MENU_SELECTION_HELP_REQUEST 


Envelope Menu Selection Help Request 
command reception 


EVENT_CALL_CONTROL_B Y_S IM 


Envelope Call Control by SIM command 
reception 


EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 


Envelope MO Short Message Control by SIM 
command reception 


EVENT_TIMER_EXPIRATION 


Envelope Timer Expiration 


EVENT_EVENT_DOWNLOAD_MT_CALL 


Envelope Event Download - MT call 


EVENT_EVENT_DOWNLOAD_CALL_CONNECTED 


Envelope Event Download - Call connected 


EVENT_EVENT_DOWNLOAD_CALL_DISCONNECTED 


Event Download - Call disconnected 


EVENT_EVENT_DOWNLOAD_LOCATION_STATUS 


Envelope Event Download - Location status 


EVENT_EVENT_DOWNLOAD_USER_ACTIVITY 


Envelope Event Download - User activity 


EVENT_EVENT_DOWNLOAD_IDLE_SCREEN_AVAILABLE 


Envelope Event Download - Idle screen available 


EVENT_EVENT_DOWNLOAD_CARD_READER_STATUS 


Envelope Event Download - Card Reader Status 


EVENT_STATUS_COI«AND 


Status APDU command event 


EVENT_UNRECOGNIZED_ENVELOPE 


Unrecognized Envelope command reception 



Parameters error 
No requirements 

Context errors 
No requirements 

6.2.2.1.2 



Test suite files 



The method is tested in the Framework 



6.2.2.1.3 



Test Coverage 



CRR number 


Test case number 


CRRN1 


Tested in Framework 


CRRN2 


Tested in Framework 



6.2.3 Class EditHandler 

It is not possible to test the methods provided by this class as it is declared 'abstract'; it will be done in the class 
inheriting it: EnvelopeResponseHandler, ProactiveHandler. 

6.2.4 Class EnvelopeHandler 

6.2.4.1 sim.tookit.EnvelopeHandler.getEnvelopeTag_1 

Test Area Reference: API_2_ENH_GENT 

6.2.4.1.1 Conformance Requirement: 

The method with following header shall be compliant to its definition in the API. 

public byte getEnvelopeTag ( ) 
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Normal execution 

CRRNl: The method shall return the Envelope BER-TLV tag. 

CRRN2: The Envelope BER TAG is available for all triggered toolkit applets from the invocation to the termination 
of their processToolkit method if the EnvelopeHandler is available. 

Parameters error 

Context errors 



6.2.4.1.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.4.1.3 



Test suite files 

API_2_ENH_GENT_1 .scr 
API_2_ENH_GENT_1 .Java 
API_2_ENH_GENT_1 .Idr 
API_2_ENH_GENT_1 .clr 

Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


getEnvelopeTag called just after triggering of the 
application. 


Returns OxD1 




2 


getEnvelopeTag called after a proactive 
command. 


Returns OxD1 




3 


getEnvelopeTag called after a second proactive 
command. 


Returns OxD1 





6.2.4.1.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3 


N2 


1,2,3 



6.2.4.2 sim.tookit.EnvelopeHandler.getltemldentifieM 

Test Area Reference: API_2_ENH_GIID 

6.2.4.2.1 Conformance Requirement: 

The method with following header shall be compliant to its definition in the API. 

public byte getltemldentif ier ( ) 

throws ToolkitException 

Normal execution 

CRRNl :The method shall return the item identifier byte value. 

CRRN2:The item identifier byte value returned shall be from the first Item Identifier TLV element. 

CRRN3: If the element is available it becomes the TLV selected. 

CRRN4: The item identifier is available for all triggered toolkit applets from the invocation to the termination of 
their processToolkit method if the EnvelopeHandler is available. 
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Parameters error 

Context errors 

CRRCl: The method shall throw ToolkitException (UNAVAILABLE_ELEMENT) if the item identifier TLV is not 
present. 

CRRC2: The method shall throw ToolkitException (OUT_OF_TLV_BOUND ARIES) if the item identifier byte is 
missing in the Item Identifier Simple TLV. 



6.2.4.2.2 

Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.4.2.3 



Test suite files 

API_2_ENH_GIID_1 .scr 
API_2_ENH_GIID_1 .j ava 
API_2_ENH_GIID_1 .Mr 
API_2_ENH_GIID_1 .clr 

Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send envelope SMS-PP Formatted with item 
identifier TLV and identifier value of 03 


Returns 03 




2 


Send envelope SMS-PP Formatted with two item 
identifier TLV with first value FF and second 44 


Returns FF 




3 


Send envelope SMS-PP Formatted with two item 
identifier TLV with first value 81 and second 44, 
call twice the method getltemldentifier 


Returns 81 
Returns 81 




4 


Send envelope SMS-PP Formatted with item 
identifier TLV and value of 66. FindTLV with TAG 
02. getltemldentifier and then getValueByte with 
offset 


getltemldentifier=getValueByte 




5 


Send envelope SMS-PP Formatted without item 
identifier TLV and getltemldentifier 


ToolkitException 
(UNAVAILABLE ELEMENT) 




6 


Send Envelope SMS-PP Formatted with item 
identifier TLV (66), send proactive command. Then 
getltemldentifier 


Returns 66 




7 


Send Envelope SMS-PP Formatted with Item 
identifier TLV but without item number 


ToolkitException 

(OUT OF TLV BOUNDARIES) 





6.2.4.2.4 



Test Coverage 



CRR number 


Test case number 


N1 


1, 2, 3 


N2 


2,3 


N3 


4 


N4 


6 


CI 


5 


C2 


7 



6.2.4.3 sim.tookit.EnvelopeHandler.getSecuredDataLength_1 

Test Area Reference: API_2_ENH_GSDL 

6.2.4.3.1 Conformance Requirement: 

The method with following header shall be compliant to its definition in the API. 

public short getSecuredDataLength ( ) 

throws ToolkitException 
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Normal execution 

CRRNl: The method shall return the length of the secured data contained in a SMS TPDU TLV. 

CRRN2: The length is from the first SMS TPDU TLV. 

CRRN3: The length should not include padding bytes. 

CRRN4: The method can be used if the event is EVENT_FORMATTED_SMS_PP_ENV and if the SMS TP-UD is 
formatted according to GSM03.48. 

CRRN5: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD and if the SMS TP-UD is 
formatted according to GSM03.48. 

CRRN6: If the method is successful, the selected TLV should be the SMS TPDU TLV. 
Parameters error 

Context errors 

CRRCl: The method shall thrown ToolkitException (UNAVAILABLE_ELEMENT) in case of unavailable SMS 
TPDU TLV element. 

CRRC2: The method shall thrown ToolkitException (UNAVAILABLE_ELEMENT) in case of missing Secured 
Data. 

6.2.4.3.2 Test suite files 

Specific triggering: 

- SMS CB 

- FORMATTED SMS PP UPD 

- UNFORMATED SMS PP ENV 

Test Script: API_2_ENH_GSDL_Lscr 

Test Applet: API_2_ENH_GSDL_l.java 

Load Script: API_2_ENH_GSDL_l.ldr 

Clean-up Script: API_2_ENH_GSLD_l.clr 



6.2.4.3.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Test with various length of TP-OA 

1 . Send a SMS PP with TP-OA =2 

2. Send a SMS PP with TP-OA =6 

3. Send a SMS PP with TP-OA =1 2 


Returns 0x2A 
(for each sub case) 




2 


Test with various length of RC/CC/DS 

1 . Send a SMS PP with RC/CC/DS = 


Returns 0x10 

(for each sub case) 




3 


Test with PCNTR = 


Returns 0x10 




4 


Test with PCNTR = 7 


Returns 0x05 




5 


Test with SecuredDataLength = 00 


Returns 0x00 




6 


Test with UserDataLength = 0x33 


Returns 0x33 




7 


Test with UserDataLength = Ox 6C 


Returns Ox 6C 




8 


Test with UserDataLength = Ox 6D 


Returns Ox 6D 




9 


Test with UserDataLength = maximum length: 
0x79 


Returns Ox 79 




10 


Verify it is the first TPDU TLV: 

Send a SMS PP with 2 TPDU TLV and inside two 

different secured data lengths: 5 and 10 


Returns 0x05 
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11 


Same test as 1 but with 
FORMATTED SMS PP UPD 


Returns 0x2A 




12 


Same test as 2 but with 
FORMATTED SMS PP UPD 


Returns 0x10 




13 


Same test as 3 but with 
FORMATTED SMS PP UPD 


Returns 0x10 




14 


Same test as 4 but with 
FORMATTED SMS PP UPD 


Returns 0x05 




15 


Same test as 5 but with 
FORMATTED SMS PP UPD 


Returns 0x00 




16 


Same test as 6 but with 
FORMATTED SMS PP UPD 


Returns 0x33 




17 


Same test as 7 but with 
FORMATTED SMS PP UPD 


Returns Ox 6C 




18 


Same test as 8 but with 
FORMATTED SMS PP UPD 


Returns Ox 6D 




19 


Same test as 9 but with 
FORMATTED SMS PP UPD 


Returns Ox 79 




20 


Same test as 1 but with 
FORMATTED SMS PP UPD 


Returns 0x05 




21 


Verify after call of the method the current TLV is 
the TPDU TLV: 

findTLV device identities, getSecuredDataLength 
and then getValueByte to verify that the current 
TLV is the TPDU TLV 


getValueByte returns 0x40 




22 


Send an envelope SMS CB, 
getSecuredDataLength 


ToolkitException 
UNAVAILABLE ELEMENT 




23 


Send an envelope SMS PP unformatted 


ToolkitException 
UNAVAILABLE ELEMENT 





6.2.4.3.4 Test Coverage 

This method has only been tested with SMS PP without security and the tests shall be improved during 03.48 tests. 



CRR number 


Test case number 


N1 


1,2,3,4,5,6,7,8,9, 10 


N2 


10 


N3 


3,4 


N4 


1,2,3,4,5,6,7,8,9,10, 
25 


N5 


11, 12, 13, 14, 15, 16, 17, 
18, 19,20 


N6 


21 


C1 


22 


C2 


23 



6.2.4.4 sim.tookit.EnvelopeHandler.getSecuredDataOffseM 

Test Area Reference: API_2_ENH_GSDO 

6.2.4.4.1 Conformance Requirement: 

The method with following header shall be compliant to its definition in the API. 

public short getSecuredDataOf f set ( ) 

throws ToolkitException 

Normal execution 

CRRNl: The method shall return the offset of the secured data first byte contained in a SMS TPDU TLV. 
CRRN2: The offset is from the first SMS TPDU TLV. 
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CRRN3: The method can be used if the event is EVENT_FORMATTED_SMS_PP_ENV and if the SMS TP-UD is 
formatted according to GSM03.48. 

CRRN4: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD and if the SMS TP-UD is 
formatted according to GSM03.48. 

CRRN5: If the method is successful, the selected TLV should be the SMS TPDU TLV. 
Parameters error 

Context errors 

CRRCl: The method shall thrown ToolkitException (UNAVA1LABLE_ELEMENT) in case of unavailable SMS 
TPDU TLV element. 

CRRC2: The method shall thrown ToolkitException (UNAVAILABLE_ELEMENT) in case of missing Secured 
Data. 

6.2.4.4.2 Test suite files 

Specific triggering: 

SMS CB 

F0RI^4ATTED SMS PP UPD 

UNFORMATED SMS PP ENV 



Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



API_2_ENH_GSDO_Lscr 
API_2_ENH_GSDO_l .Java 
API_2_ENH_GSDO_l .Idr 
API 2 ENH GSDO l.clr 



6.2.4.4.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Test with TP-OA length of 2 


Returns 0x21 




2 


Test with TP-OA length of 6 


Returns 0x23 




3 


Test with TP-OA length of 12 


Returns 0x26 




4 


Test with RC/CC/DS length of 


Returns 0x21 




5 


Send a SMS PP with 2 TPDU TLV and inside two 
different secured data offsets 


Returns 0x24 ( the first offset ) 




6 


Same test as 1 but with 
FORMATTED SMS PP UPD 


Returns 0x21 




7 


Same test as 2 but with 
FORMATTED SMS PP UPD 


Returns 0x23 




8 


Same test as 3 but with 
FORMATTED SMS PP UPD 


Returns 0x26 




9 


Same test as 4 but with 
FORMATTED SMS PP UPD 


Returns 0x21 




10 








11 


Same test as 5 but with 
FORMATTED SMS PP UPD 


Returns 0x24 ( the first offset ) 




12 


Verify after call of the method the current TLV is 
the TPDU TLV: 

findTLV device identities, getSecuredDataOffset 
and then getValueByte to verify that the current 
TLV is the TPDU TLV 


Returns 0x40 




13 


Send an envelope SMS CB, 
getSecuredDataOffset 


ToolkitException 
UNAVAILABLE ELEMENT 




14 








15 


Send an envelope SMS PP unformatted 


ToolkitException 
UNAVAILABLE ELEMENT 




16 


Send an envelope SMS-PP formatted with no 
secured data , getSecuredDataOffset 


Returns 0x21 
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6.2.4.4.4 Test Coverage 

This method has only been tested with SMS PP without security and the tests shall be improved during 03.48 tests. 



CRR number 


Test case number 


N1 


1,2,3,4,5, 14 


N2 


5 


N3 


1,2,3,4,5, 15 


N4 


6,7,8,9, 10 


N5 


11 


C1 


12 


C2 


13 



6.2.4.5 sim.tookit.EnvelopeHandler.getTheHandleM 

6.2.4.5.1 Conformance Requirements 

The method with following header shall be compliant to its definition in the API. 

public static EnvelopeHandler getTheHandler ( ) 

throws ToolkitException 

Normal execution 

CRRNl: The method shall return the single system instance of the EnvelopeHandler class. 

CRRN2: The EnvelopeHandler is a Temporary JCRE Entry Point Object ( see Javacard 2.1 Runtime Environment 
(JCRE) Specification [12]) 

Parameters error 

Context errors 

CRRCl: The method shall thrown ToolkitException (HANDLER_NOT_AV AIL ABLE) if the handler is busy. 



6.2.4.5.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.4.5.3 



Test suite files 

API_2_ENH_GTHD_1 .scr 
API_2_ENH_GTHD_1 .Java 
API_2_ENH_GTHD_1 .Idr 
API_2_ENH_GTHD_1 .clr 

Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


getTheHandler twice 


The returned objects shall be the 
same 




2 


Verify that getTheHandler returns an 

EnvelopeHandler 

GetTheHandler 


The reference returned shall be an 
EnvelopeHandler (checl<cast) 




3 


Verify the returned value is not null 
GetTheHandler 


The reference returned shall not be 
null. 
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6.2.4.5.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3 


N2 


To be checked in 

Framework tests and 

insert here cross 

reference 


C1 


To be checked in 

Framework tests and 

insert here cross 

reference 



6.2.4.6 sim.tookit.EnvelopeHandler.getTPUDLOffseM 

Test Area Reference: API_2_ENH_GTPO 

6.2.4.6.1 Conformance Requirement: 

The method with following header shall be compliant to its definition in the API. 

public short getTPUDLOf f set ( ) 

throws ToolkitException 

Normal execution 

CRRNl: The method shall return the TPUDL offset in a SMS TPDU TLV. 

CRRN2: The offset is from the first SMS TPDU TLV. 

CRRN3: The method can be used if the event is EVENT_FORMATTED_SMS_PP_ENV. 

CRRN4: The method can be used if the event is EVENT_FORMATTED_SMS_PP_UPD. 

CRRN5: The method can be used if the event is EVENT_UNFORMATTED_SMS_PP_ENV. 

CRRN6: The method can be used if the event is EVENT_UNFORMATTED_SMS_PP_UPD. 

CRRN7: If the method is successful, the selected TLV should be the SMS TPDU TLV. 

Parameters error 

Context errors 

CRRCl: The method shall thrown ToolkitException (UNAVAILABLE_ELEMENT) in case of unavailable SMS 
TPDU TLV element. 

CRRC2: The method shall thrown ToolkitException (UNAVAILABLE_ELEMENT) if the TPUDL field does not exist. 

6.2.4.6.2 Test suite files 
Specific triggering: 

FORMATTED SMS PP UPD 
UNFORMATTED SMS PP UPD 
UNFORMATTED SMS PP ENV 
SMS CB 



Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



API_2_ENH_GTPO_l .scr 
API_2_ENH_GTPO_l .Java 
API_2_ENH_GTP0_1 .Idr 
API_2_ENH_GTPO_l .clr 
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6.2.4.6.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Test with TP-OA length of 2 


Returns OxOD 




2 


Test with TP-OA length of 6 


Returns OxOF 




3 


Test with TP-OA length of 12 


Returns 0x12 




4 


Send a SMS PP with 2 TPDU TLV and inside two 
different UDL offsets 


Returns 0x10 ( the first offset ) 




5 


Same test as 1 but with 
FORMATTED SMS PP UPD 


Returns OxOD 




6 


Same test as 2 but with 
FORMATTED SMS PP UPD 


Returns OxOF 




7 


Same test as 3 but with 
FORMATTED SMS PP UPD 


Returns 0x12 




8 


Same test as 4 but with 
FORMATTED SMS PP UPD 


Returns 0x10 ( the first offset ) 




9 


Same test as 1 but with 
UNFORMAI IbD SMS PP UPD 


Returns OxOD 




10 


Same test as 2 but with 
UNFORMAI IbD SMS PP UPD 


Returns OxOF 




11 


Same test as 3 but with 
UNFORMAI IbD SMS PP UPD 


Returns 0x12 




12 


Same test as 4 but with 
UNFORMAI IbD SMS PP UPD 


Returns 0x12 ( the first offset ) 




13 


Same test as 1 but with 
UNFORMAI IbD SMS PP ENV 


Returns OxOD 




14 


Same test as 2 but with 
UNFORMAI IbD SMS PP ENV 


Returns OxOF 




15 


Same test as 3 but with 
UNFORMAI IbD SMS PP ENV 


Returns 0x12 




16 


Same test as 4 but with 
UNFORMAI IbD SMS PP ENV 


Returns 0x10 ( the first offset ) 




17 


Verify after call of the method the current TLV is the 
TPDU TLV: 

findTLV device identities, getTPUDLOffset and then 
getValueByte to verify that the current TLV is the 
TPDU TLV 


Returns 0x40 




18 


Send an envelope SMS CB, getTPUDLOffset 


ToolkitException 
UNAVAILABLE ELEMENT 





6.2.4.6.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3,4,5,6,7,8,9,10, 
11, 12, 13, 14, 15, 16, 17 


N2 


4 


N3 


1,2,3,4, 17 


N4 


5, 6, 7, 8 


N5 


13, 14, 15, 16 


N6 


9, 10, 11, 12 


N7 


17 


CI 


18 


C2 


Don't no how to test 



6.2.4.7 sim.tookit.EnvelopeHandler.getLength_1 

Test Area Reference: API_2_ENH_GLEN 

6.2.4.7.1 Conformance Requirement 

The method with following header shall be compliant to its definition in the API. 

public short getLengthO 



£75/ 



ETSI TS 101 955 V7.1.0 (2001-06) 



3GPP TS 11.13 version 7.1.0 Release 1998 71 

throws ToolkitException 

Normal execution 

CRRNl: returns the length in bytes of the TLV list. 

Parameter Error 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 

6.2.4.7.2 Test Suite files 

Specific triggering: None 

Test Script: 

Test Applet: 

Load Script: 

Clean-up Script: 



API_2_ENH_GLEN_1 .scr 
API_2_ENH_GLEN_1 .Java 
API_2_ENH_GLEN_1 .Idr 
API_2_ENH_GLEN_1 .clr 



6.2.4.7.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send an envelope SMS PP with BER length of 
0x31 


Result of getLengthO is 0x0031 




2 


Send an envelope SMS PP with BER length of 
0x7F 


Result of getLengthO is 0x007Fh 




3 


Send an envelope SMS PP with BER length of 
81 80 


Result of getLengthO is 0x0080h 




4 


Send an envelope SMS PP with BER length of 
81 FC 


Result of getLengthO is OxOOFCh 





6.2.4.7.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3,4 


CI 


Does not apply for 
EnvelopeHandler 



6.2.4.8 sim.tookit.EnvelopeHandler.copy_1 

Test Area Reference: API_2_ENH_COPY_BSS 

6.2.4.8.1 Conformance Requirement 

The method with following header shall be compliant to its definition in the API. 

public short copy (byte [] dstBuffer, 
short dstOffset, 
short dstLength) 

throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: copies the simple TLV list contained in the handler to the destination byte array. 
CRRN2: returns dstOffset + dstLength. 
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Parameter errors 

CRRPl: if dstBuffer is null a NullPointerException is thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative, an 
ArraylndexOutOfBoundsException is thrown. 

CRRP3: if dstLength is grater than the length of the simple TLV List, an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException. OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

6.2.4.8.2 Test Suite files 

Specific triggering: None 

Test Script: 

Test Applet: 

Load Script: 

Clean-up Script: 



API_2_ENH_C0PY_BSS_Lscr 
API_2_ENH_C0PY_BSS_1 .Java 
API_2_ENH_C0PY_BSS_1 .Idr 
API_2_ENH_ COPY _ BSS _Lclr 



6.2.4.8.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


NULL as parameter to dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 


ArraylndexOutOfBoundsException is 






dstBuffer . length = 5 


thrown 






dstOffset = 5 








dstLength = 1 






3 


dstOffset < 


ArraylndexOutOfBoundsException is 






dstBuffer.length = 5 


thrown 






dstOffset = -1 








dstLength = 1 






4 


dstLength > dstBuffer.length 


ArraylndexOutOfBoundsException is 






dstBuffer.length = 5 


thrown 






dstOffset = 








dstLength = 6 






5 


DstOffset + dstLength > dstBuffer.length 


ArraylndexOutOfBoundsException is 






DstBuffer.length = 5 


thrown 






DstOffset = 3 








DstLength = 3 






6 


dstLength < 


ArraylndexOutOfBoundsException is 






dstBuffer.length = 5 


thrown 






dstOffset = 








dstLength = -1 






7 


DstLength > length of the simple TLV list 


ToolkJtException.OUT OF TLV BO 






DstBuffer.length = 48 


UNDARIES is thrown 






DstOffset = 








DstLength = 48 






8 


Successful call, dstBuffer is the whole buffer 

DstBuffer.length = 47 
DstOffset = 
DstLength = 47 


Result of copyO is 0X0047 




9 


Compare the buffer 


Result of arrayCompareO is 




10 


Successful call, dstBuffer is part of a buffer 

DstBuffer.length = 50 
dstOffset = 3 
dstLength = 47 


Result of copyO is 0X0032 




11 


Compare the whole buffer 


Result of arrayCompareO is 




12 


Successful call, dstBuffer is part of a buffer 

dstBuffer.length = 15 
dstOffset = 3 


Result of copyO is 0X0009 
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dstLength = 6 






13 


Compare the whole buffer 


Result of arrayCompareO is 




14 


Successful call, dstBuffer is part of a buffer 

dstBuffer. length = 260 
dstOffset = 257 
dstLength = 3 


Result of copyQ is 0X0104 




15 


Compare the whole buffer 


Result of arrayCompareO is 




16 


Successful call, copy with length =0 

dstBuffer. length = 260 
dstOffset = 260 
dstLength = 


Result of copyQ is 0x1 04 





6.2.4.8.4 



Test Coverage 



CRR number 


Test case number 


N1 


9, 11, 13, 15 


N2 


8, 10, 12, 14, 16 


PI 


1 


P2 


2,3,4,5,6 


P3 


7 


CI 


Does not apply for 
EnvelopeHandler 



6.2.4.9 sim.tookit.EnvelopeHandler.findTLV_1 

Test Area Reference: API_2_ENH_FINDBB 

6.2.4.9.1 Conformance Requirement 

The method with following header shall be compliant to its definition in the API. 

public byte findTLV(byte tag, byte occurrence) 
throws ToolkitException 

Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of the TLV list (handler buffer): 

CRRNl: the method is successful if the required occurrence exists then the corresponding TLV becomes current. 

CRRN2: if the method is successful then it returns TLV_FOUND_CR_SET when Comprehension Required flag is 

set. 

CRRN3: if the method is successful then it returns TLV_FOUND_CR_NOT_SET when Comprehension Required 
flag is not set. 

CRRN4: if the required occurrence of the TLV element does not exist, the current TLV is no longer defined and 
TLV_NOT_FOUND is returned. 

CRRN5: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl : if an input parameter is not valid (e.g. occurrence = 0) an instance of ToolkitException shall be thrown. 
The reason code shall be ToolkitException BAD_INPUT_PARAMETER. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 
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Test Applet: 
Load Script: 
Clean-up Script: 

6.2.4.9.3 



API_2_ENH_ENH_FINDBB_1 .scr 
API_2_ENH_ENH_FINDBB_1 .Java 
API_2_ENH_ENH_FINDBB_1 .Idr 
API 2 ENH FINDBB l.clr 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 




Trig the applet with SMS PP including one more 
tag 02 and one TAG 04 






1 


Invalid input parameter 

Occurrence = 


ToolkitException.BAD INPUT P 
ARAMETER is thrown 




2 


Search 1 St TLV 

Tag = 02h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




3 


Call the getValueLengthO method 


Result is 0x02 




4 


Search 2nd TLV 

Tag = 06h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




5 


Call the getValueLengthO method 


Result is 0x05h 




6 


Select a TLV (tag 02h) 








Search a wrong tag 

Tag = 03h 
Occurrence = 1 


Result is TLV_NOT_FOUND 




7 


Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




8 


Search a tag with wrong occurrence 

Tag = 02h 
Occurrence = 3 


Result is TLV_NOT_FOUND 




9 


Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




10 


Search the TLV 

Tag = 02h 
Occurrence = 2 


Result is 
TLV_FOUND_CR_NOT_SET 




11 


Search the TLV 

Tag = 04h 
Occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 




12 


Search tag 81 h 

Tag = 86h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




13 


Search tag 84h 

Tag = 84h 
Occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 





6.2.4.9.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,5 


N2 


2,4 


N3 


10, 11 


N4 


6,7,8,9 


N5 


12, 13 


PI 


1 


CI 


Does not apply for 
EnvelopeHandler 
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6.2.4.1 sim.tookit.EnvelopeHandler.getValueLength_1 

Test Area Reference: API_2_ENH_GVLE 

6.2.4.10.1 Conformance Requirement 

The method with following header shall be compliant to its definition in the API. 

public short getValueLength ( ) 

throws ToolkitException 

Normal execution 

CRRNl: gets and returns the binary length of the value field for the last TLV element which has been found in the 
handler. 

Parameter errors 



Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 

6.2.4.10.2 Test Suite files 

Specific triggering: None 

Test Script: 

Test Applet: 

Load Script: 

Clean-up Script: 



API_2_ENH_GVLE_1 .scr 
API_2_ENH_GVLE_1 .Java 
API_2_ENH_GVLE_1 .Idr 
API 2 ENH GVLE Lclr 



6.2.4.10.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 




Fill the SMS PP with TLV: Tag 33, Length C8 






1 


getValueLengthO 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




2 


Search TLV 02h 








getValueLength ( ) 


Result is 0X0002 




3 


Search TLV OBh 








getValueLength ( ) 


Result is 0X0024 




4 


Search TLV 33h 








getValueLength ( ) 


Result is 0X00C8 





6.2.4.10.4 



Test Coverage 



CRR number 


Test case number 


N1 


2, 3,4 


C1 


Does not apply for 
EnvelopeHandler 


C2 


1 
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6.2.4.1 1 sim.tookit.EnvelopeHandler.getValueByte_1 

Test Area Reference: API_2_ENH_GVBYS 

6.2.4.11.1 Conformance Requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getValueByte (short valueOffset) 
throws ToolkitException 

Normal execution 

CRRNl: Gets a byte from the last TLV element which has been found in the handler and returns its value (1 byte). 

Parameter errors 

CRRPl: if valueOffset is out of the current TLV an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 

6.2.4.11.2 Test Suite files 
Specific triggering: None 

Test Script: API_2_ENH_GVBY.scr 

Test Applet: API_2_ENH_GVBY_Ljava 

Load Script: API_2_ENH_GVBY.ldr 



6.2.4.11.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 




Fill the SMS PP with TLV: Tag 33, Length C8 
Valued 02... 






1 


getValueByte{0) 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




2 


Search TLV 02h 








getValueByte (2) 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




3 


Search TLV 02h 








getValueByte (1) 


Result is 0x81 




4 


Search TLV 02h (Device Identities TLV) 








getValueByte (0) 


Result is 83h (Source) 




5 


Search TLV 33h 








getValueByte (7E) 


Result is 0x7F 




6 


Search TLV 33h 








getValueByte (80) 


Result is 0x81 




7 


getValueByte (7F) 


Result is 0x80 




8 


Search TLV B3h 








getValueByte (C7) 


Result is 0xC8 
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6.2.4.11.4 



Test Coverage 



CRR number 


Test case number 


N1 


3, 4, 5, 6, 7, 8 


P1 


2 


C1 


Does not apply for 
EnvelopeHandler 


C2 


1 



6.2.4.1 2 sim.tookit.EnvelopeHandler.copyValue_1 

Test Area Reference: API_2_ENH_CPYVS_BSS 

6.2.4.12.1 Conformance Requirement 

The method with following header shall be compliant with its definition in the API. 

public short copyValue (short valueOffset, 

byte[] dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: copies a part of the last TLV element which has been found, into a destination, buffer. 
CRRN2: returns dstOffset + dstLength. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException is thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException is thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 

6.2.4.12.3 Test Suite files 

Specific triggering: None 

Test Script: 

Test Applet: 

Load Script: 

Clean-up Script: 



API_2_ENH_CPYVS_BSS_1 .scr 
API_2_ENH_CPYVS_BSS_1 .Java 
API_2_ENH_CPYVS_BSS_1 .Mr 
API 2 ENH CPYVS BSS l.clr 
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6.2.4.12.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Search TLV 02h 








copyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


Search TLV OBh 








dstOffset > dstBuffer.length 

dstBuffer . length = 5 
dstOffset = 5 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Search TLV 06h 








valueOffset > TLV Length 

valueOffset = 6 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > TLV length 

valueOffset = 
dstBuffer.length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > TLV length 

valueOffset = 2 
dstBuffer.length = 15 
dstOffset = 
dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Search TLV 01 h 








copyValue () 


ToolkitException.UNAVAILABLE 
_ELEMENT is thrown on the 
copyValueO method 




12 


Search TLV 06h 








Successful call 

valueOffset = 
dstBuffer.length = 6 
dstOffset = 
dstLength = 6 


Result of copyValueO is 0x0006 




13 


Compare buffer 

buffer = 81 11 22 33 44 F5 


Result is OOh 




14 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

valueOffset = 1 
dstBuffer.length = 20 
dstOffset = 3 
dstLength = 4 


Result of copyValueO is 0x0007 




15 


Compare buffer 

buffer = 
55 55 55 11 22 
33 44 55 55 55 
55 55 55 55 55 
55 55 55 55 55 


Result is OOh 




16 


Successful call, copy with length =0 


Result of copyValueO is 20 
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dstBuffer. length = 20 
dstOffset = 20 
dstLength = 







6.2.4.12.4 



Test Coverage 



CRR number 


Test case number 


N1 


13,15 


N2 


12, 14, 16 


P1 


1 


P2 


2,3,4,5,6 


P3 


7,8,9, 10 


C1 


Does not apply for 
EnvelopeHandler 


C2 


11 



6.2.4.1 3 sim.tookit.EnvelopeHandler.compareValue_1 

Test Area Reference: API_2_ENH_CPRVS_BSS 



6.2.4.13.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public byte compareValue (short valueOffset, 

byte[] compareBuf f er, 
short compareOf f set, 
short compareLength) 
throws Java . lang . NullPointerException, 

Java .lang . Array I ndexOut Of Bounds Except ion, 
ToolkitException 

Normal execution 

Compares the last found TLV element with a buffer: 

CRRNl: returns if identical. 

CRRN2: returns -1 if the first miscomparing byte in simple TLV List is less than that in compareBuffer. 

CRRN3: returns 1 if the first miscomparing byte in simple TLV List is greater than that in compareBuffer. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if compareLength 
is negative ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 

6.2.4.13.3 Test Suite files 

Specific triggering: None 
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Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.4.13.3 



API_2_ENH_CPRVS_BSS_1 .scr 
API_2_ENH_CPRVS_BSS_1 .Java 
API_2_ENH_CPRVS_BSS_1 .Idr 
API_2_ENH_CPRVS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Search TLV 02h 








compareValue ( ) with a null compareBuf f er 


NullPointerException is thrown 




2 


Search TLV OBh 








compareOffset > compareBuffer.length 

compareBuf fer . length = 5 
compareOffset = 5 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 5 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


compareLength >compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 
>compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Search TLV 06h 








valueOffset > TLV Length 

valueOffset = 6 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


compareLength > TLV length 

valueOffset = 
compareBuffer.length = 15 
compareOffset = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > TLV length 

valueOffset = 2 
compareBuffer.length = 15 
compareOffset = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Search TLV 01 h 


Result is TLV NOT FOUND 






compareValue () 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown 




12 


Search TLV 06h 








Initialise compareBuffer 

compareBuf fer = 
81 11 22 33 44 F5 








Compare buffers 

valueOffset = 
compareOffset = 
compareLength = 6 


Result is OOh 




13 


Initialise compareBuffer 

compareBuffer = 
7F 11 22 33 44 F5 








Compare buffers with same parameters 


Result is -1 
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14 


Initialise compareBuffer 

compareBuf fer = 
83 11 22 33 44 F5 








Compare buffers with same parameters 


Result is -1 




15 


Initialise compareBuffer 

compareBuffer = 

55 55 55 81 11 22 33 44 F5 

55 55 55 55 55 








Compare buffers 

valueOffset = 1 
compareOf f set = 4 
compareLength = 5 


Result is OOh 




16 


Initialise compareBuffer 

compareBuffer = 

55 55 55 81 10 22 33 44 F5 

55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




17 


Initialise compareBuffer 

compareBuffer = 

55 55 55 81 12 22 33 44 F5 

55 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




18 


Successful call, compareValue with length =o 

CompareBuf fer . length = 15 
CompareOf f set = 15 
CompareLength = 


Result of compareValueO is 





6.2.4.13.4 



Test Coverage 



CRR number 


Test case number 


N1 


12, 15 


N2 


13, 16, 18 


N3 


14, 17 


PI 


1 


P2 


2,3,4,5,6 


P3 


7,8,9, 10 


CI 


Does not apply for 
EnvelopeHandler 


C2 


11 



6.2.4.14 sim.tookit.EnvelopeHandler.findAndCopyValue_1 

Test Area Reference: API_2_ENH_FACYB_BS 

6.2.4.14.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte[] dstBuffer, 

short dstOffset) 
throws Java . lang . NullPointerException, 
Java .lang . ArraylndexOutOfBoundsException, 

ToolkitException 

Normal execution 

CRRNl: looks for the first occurrence of a TLV element from the beginning of a TLV list and copy its value into a 
destination buffer. 

CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + length of the 
copied value is returned. 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



82 



ETSI TS 101 955 V7.1.0 (2001-06) 



CRRN4: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException shall be thrown. 

CRRP2: if dstOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitExceptionHANDLER_NOT_AVAILABLE. 

6.2.4.14.3 Test Suite files 

Specific triggering: None 

Test Script: 

Test Applet: 

Load Script: 

Clean-up Script: 



AP1_2_ENH_FACYB_BS_1 .scr 
API_2_ENH_FAC YB_BS_1 .Java 
AP1_2_ENH_FAC YB_BS_1 .Idr 
API 2 ENH FACYB BS l.clr 



6.2.4.14.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 




Fill the SMS PP with TLV: Tag 02 Value 22 44 
Tag 33, Length C4 Value 01 02 ... 






1 


FindAndCopyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

tag = 06h 

dstBuffer.length = 06 
dstOffset = 06 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


dstOffset < 

dstBuffer.length = 06 
dstOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > dstBuffer.length 

dstBuffer.length = 05 
dstOffset = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


DstOffset + length >dstBuffer.length 

DstBuffer.length = 06 
DstOffset = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


Select a TLV (tag 02h) 








findAndCopyValueO 

tag = 03h 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 






Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




7 


Successful call 

Tag = 06h 

DstBuffer.length = 06 
DstOffset = 


Result of findAndCopyValue () is 
0006 




8 


Compare buffer 

buffer = 81 11 22 33 44 F5 


Result Is OOh 




9 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

dstBuffer.length = 12 
dstOffset = 2 


Result of findAndCopyValue () is 
0008 




10 


Compare buffer 

buffer = 

55 55 81 11 22 33 44 F5 55 55 55 55 


Result is OOh 




11 


Successful call 

tag = 02h 
dstBuffer.length = 2 


Result of findAndCopyValue () is 
0002 
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dstOffset = 






12 


Compare buffer 

buffer = 83 81 


Result is OOh 




13 


Successful call (with tag 82h) 

tag = 82h 

dstBuffer. length = 02 

dstOffset = 


Result of findAndCopyValue () is 
0002 




14 


Compare buffer 

buffer = 83 81 


Result is OOh 




15 


Successful call (with tag B3h) 

tag = B3h 

dstBuffer. length = C4 

dstOffset = 


Result of findAndCopyValue () is 
00C4 




16 


Compare buffer 

buffer = 01 02 ... C4 


Result is OOh 





6.2.4.14.4 



Test Coverage 



CRR number 


Test case number 


N1 


8, 10, 12 


N2 


6 


N3 


7, 9, 11 


N4 


13, 14, 15, 16 


PI 


1 


P2 


2, 3, 4, 5 


CI 


Does not apply for 
EnvelopeHandler 



6.2.4.1 5 sim.tookit.EnvelopeHandler.findAndCopyValue_2 

Test Area Reference: API 2 ENH FACYBS BSS 



6.2.4.15.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short findAndCopyValue (byte tag, 

byte occurence, 

short valueOffset, 

byte[] dstBuffer, 

short dstOffset, 

short dstLength) 
throws Java . lang.NullPointerException, 
Java . lang. ArraylndexOutOfBoundsException, 

Toolkit Except ion 

Normal execution 

CRRNl: looks for the indicated occurrence of a TLV element from the beginning of a TLV list and copy its value 
into a destination buffer. 

CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + dstLength is 
returned. 

CRRN4: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException shall be thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException shall be thrown. 
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CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 



6.2.4.15.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.4.15.3 



Test Suite files 

API_2_ENH_FACYBS_BSS_1 .scr 
API_2_ENH_FACYBS_BSS_1 .Java 
API_2_ENH_FAC YBS_BSS_1 .Mr 
API_2_ENH_FAC YBS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 




Fill the SMS PP with TLV: Tag 02 Value 22 44 
Tag 33, Length C4 Value 01 02 ... 






1 


findAndCopyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

tag = 06h, occurrence = 1 
valueOffset = 
dstBuffer.length = 5 
dstOffset = 5 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


valueOffset > Value Length 

tag = 06h, occurrence = 1 
valueOffset = 6 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > Value length 

valueOffset = 
dstBuffer.length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > Text String length 

valueOffset = 2 
dstBuffer.length = 15 
dstOffset = 
dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Select a TLV (tag 02h) 








findAndCopyValueO 


ToolkitException.UNAVAILABLE 
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tag = 06h 
occurrence = 2 


_ELEMENT is thrown 






Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




12 


Successful call 

tag = 06h, occurrence = 1 
valueOffset = 
dstBuffer .length = 06 
dstOffset = 
dstLength = 06 


Result of fincJAndCopyValueO is 
6 




13 


Compare buffer 

buffer = 81 11 22 33 44 F5 


Result is OOh 




14 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

tag = 06h, occurrence = 1 
valueOffset = 2 
dstBuffer .length = 12 
dstOffset = 3 
dstLength = 04 


Result of findAndCopyValue () is 
0007 




15 


Compare buffer 

buffer = 

55 55 55 22 33 44 F5 55 55 55 55 55 


Result is OOh 




16 


Successful call 

tag = 02h, occurrence = 1 
valueOffset = 
dstBuffer. length = 12 
dstOffset = 
dstLength = 2 


Result of findAndCopyValueO is 
0002 




17 


Compare buffer 

buffer = 83 81 55 ... 55 


Result is OOh 




18 


Successful call 

tag = 02h, occurrence = 2 
valueOffset = 
dstBuffer .length = 12 
dstOffset = 
dstLength = 2 


Result of findAndCopyValueO is 
0002 




19 


Compare buffer 

buffer = 22 44 55 ... 55 


Result is OOh 




20 


Successful call (with tag 82h) 

tag = 82h 
occurrence = 1 
valueOffset = 
dstBuffer .length = 12 
dstOffset = 
dstLength = 02 


Result of findAndCopyValue () is 
0002 




21 


Compare buffer 

buffer = 83 81 55 ... 55 


Result is OOh 




22 


Successful call (with tag 82h) 

tag = 82h 
occurrence = 2 
valueOffset = 
dstBuffer. length = 12 
dstOffset = 
dstLength = 02 


Result of findAndCopyValue () is 
0002 




23 


Compare buffer 

Buffer = 22 44 55 ... 55 


Result is OOh 




24 


Successful call, findAndCopyValue with 
length =0 

DstBuffer .length = 12 
dstOffset = 12 
dstLength = 


Result of findAndCopyValue () is 
12 
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6.2.4.15.4 



Test Coverage 



CRR number 


Test case number 


N1 


13, 15, 17, 19 


N2 


11 


N3 


12, 14, 16, 18,24 


N4 


20,21, 22,23 


P1 


1 


P2 


2,3,4,5,6 


P3 


7,8,9, 10 


CI 


Does not apply for 
EnvelopeHandler 



6.2.4.1 6 sim.tookit.EnvelopeHandler.findAndCompareValue_1 

Test Area Reference: API 2 ENH FACRB BS 



6.2.4.16.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte[] compareBuf fer, 

short compareOf f set ) 
throws Java . lang . NullPointerException, 
Java .lang . Array I ndexOut Of Bounds Except ion, 

ToolkitException 

Normal execution 

Looks for the first occurrence of a TLV element from beginning of a TLV list and compare its value with a buffer: 

CRRNl: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN2: if the method is successful then the corresponding TLV becomes current. 

CRRN3: if identical returns 0. 

CRRN4: if the first miscomparing byte in simple TLV is less than that in compareBuffer returns -1 . 

CRRN5: if the first miscomparing byte in simple TLV is greater than that in compareBuffer returns 1. 

CRRN6: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be 
thrown. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

6.2.4.16.3 Test Suite files 

Test Script: API_2_ENH_FACRB_BS_l.scr 

Test Applet: API_2_ENH_FACRB_BS_Ljava 

Load Script: API_2_ENH_FACRB_BS_Lldr 
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Clean-up Script: 



API_2_ENH_FACRB_BS_1 .clr 



6.2.4.16.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 




Fill the SMS PP with TLV: Tag 02 Value 22 44 
Tag 33, Length C4 Value 01 02 ... 






1 


findAndCompareValueO with a null dstBuffer 


NullPointerException is thrown 




2 


compareOffset > compareBuffer.length 

tag = 06h 

compareBuffer.length = 12 
compareOffset = 12 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 12 
compareOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


length > compareBuffer.length 

compareBuffer.length = 05 
compareOffset = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + length > 
compareBuffer.length 

compareBuffer.length = 12 
compareOffset = 7 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


Select a TLV (tag 02h) 








findAndCompareValueO 

tag = 03h 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown 






Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown. 




7 


Initialise compareBuffer 

compareBuffer = 81 11 22 33 44 F5 








Compare buffers 

tag = 06h 
compareOffset = 


Result is OOh 




8 


Verify current TLV 

getValueLength ( ) 


Result is 06 




9 


Initialise compareBuffer 

compareBuffer = 81 11 22 33 44 F4 








Compare buffers with same parameters 


Result is +1 




10 


Initialise compareBuffer 

compareBuffer = 81 11 22 33 44 F6 








Compare buffers with same parameters 


Result is -1 




11 


Initialise compareBuffer 

compareBuffer = 

55 55 81 11 22 33 44 F5 55 55 55 55 








Compare buffers 

compareOffset = 2 


Result is OOh 




12 


Initialise compareBuffer 

compareBuffer = 

55 55 83 81 55 55 55 55 55 55 55 55 








Compare buffers 

compareOffset = 2 


Result Is OOh 




13 


Initialise compareBuffer 

compareBuffer = 

55 55 83 80 55 55 55 55 55 55 55 55 








Compare buffers 

compareOffset = 2 


Result is +1 




14 


Initialise compareBuffer 

compareBuffer = 

55 55 83 82 55 55 55 55 55 55 55 55 








Compare buffers 

compareOffset = 2 


Result is -1 




15 


Initialise compareBuffer 

compareBuffer = 

83 81 55 55 55 55 55 55 55 55 55 55 








Successful call (with tag 02h) 

tag = 02h 

compareBuffer.length = 12 
compareOffset = 


Result is OOh 




16 


Initialise compareBuffer 

CompareBuffer = 01 02 ... C4 








Successful call (with tag B3h) 

Tag = B3h 


Result is OOh 
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CompareBuffer . length = C4 
CompareOf f set = 







6.2.4.16.4 



Test Coverage 



CRR number 


Test case number 


N1 


6 


N2 


8 


N3 


7, 11, 12 


N4 


9, 13 


N5 


10, 14 


N6 


15, 16 


P1 


1 


P2 


2, 3, 4, 5 


C1 


Does not apply for 
EnvelopeHandler 



6.2.4.1 7 sim.tookit.EnvelopeHandler.findAndCompareValue_2 

Test Area Reference: API_2_ENH_FACRBBS_BSS 

6.2.4.17.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte occurence, 
short valueOffset, 
byte[] CompareBuffer, 
short compareOf f set, 
short compareLength) 
throws Java . lang . NullPointerException, 
Java .lang . ArraylndexOutOfBoundsException, 

ToolkitException 

Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of a TLV list and compare its value with a 
buffer: 

CRRNl: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN2: if the method is successful then the corresponding TLV becomes current. 

CRRN3: if identical is returned. 

CRRN4: if the first miscomparing byte in simple TLV is less than that in CompareBuffer -1 is returned. 

CRRN5: if the first miscomparing byte in simple TLV is greater than that in CompareBuffer 1 is returned 

CRRN6: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if CompareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if compareLength 
is negative ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, compareLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

CRRP4: if an input parameter is not valid (e.g. occurence = 0) an instance of ToolkitException shall be thrown. The 
reason code shall be ToolkitException BAD_INPUT_PARAMETER. 
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Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitExceptionHANDLER_NOT_AVAILABLE. 



6.2.4.17.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.4.17.3 



Test Suite files 

API_2_ENH_FACRBBS_BSS_1 .scr 
API_2_ENH_FACRBBS_BSS_1 .Java 
API_2_ENH_FACRBBS_BSS_1 .Idr 
API_2_ENH_FACRBBS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 




Fill the SMS PP with TLV: Tag 02 Value 22 44 
Tag 33, Length C4 Value 01 02 ... 






1 


findAndCompareValueO with a null 
compareBuffer 


NullPointerException is thrown 




2 


compareOffset > compareBuffer.length 

tag = 06h, occurrence = 1 
valueOffset = 
compareBuffer.length = 6 
compareOffset = 6 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 6 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


compareLength >compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 
>compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


valueOffset > Value Length 

tag = 06h, occurrence = 1 
valueOffset = 6 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


compareLength > Value length 

valueOffset = 
compareBuffer.length = 15 
compareOffset = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > Value length 

valueOffset = 2 
compareBuffer.length = 15 
compareOffset = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Invalid parameter 

occurrence = 


ToolkitException. BAD INPUT P 
ARAMETER is thrown 




12 


Select a TLV (tag 02h) 








findAndCompareValueO 

tag = 06h 


ToolkitException.UNAVAILABLE 
_ELEMENT is thrown 
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occurrence = 2 








Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




13 


Initialise compareBuffer 

compareBuffer = 81 11 22 33 44 F5 








findAndCompareValueQ 

tag = 06h, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 6 


Result is OOli 




14 


Verify current TLV 

getValueLength ( ) 


Result is 0006 




15 


Initialise compareBuffer 

compareBuffer = 81 11 22 33 44 F4 








Compare buffers with same parameters 


Result is +1 




16 


Initialise compareBuffer 

compareBuffer = 81 11 22 33 44 F6 








Compare buffers with same parameters 


Result is -1 




17 


Initialise compareBuffer 

compareBuffer = 

55 55 55 22 33 44 F5 55 55 55 55 








Compare buffers 

valueOffset = 2 
compareOf f set = 3 
compareLength = 4 


Result is OOh 




18 


Initialise compareBuffer 

compareBuffer = 

55 55 55 22 33 45 F5 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




19 


Initialise compareBuffer 

compareBuffer = 

55 55 55 22 33 43 F5 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




20 


Initialise compareBuffer 

compareBuffer = 

83 81 55 55 55 55 55 55 55 55 55 55 








findAndCompareValueQ 

tag = 02h, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 2 


Result is OOh 




21 


Initialise compareBuffer 

compareBuffer = 

22 44 55 55 55 55 55 55 55 55 55 55 








findAndCompareValueQ 

tag = 02h, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 2 


Result is OOh 




22 


Initialise compareBuffer 

compareBuffer = 

22 45 55 55 55 55 55 55 55 55 55 55 








findAndCompareValueQ 

tag = 02h, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 2 


Result is -1 




23 


Initialise compareBuffer 

compareBuffer = 

83 81 55 55 55 55 55 55 55 55 55 55 








Successful call (with tag 02h) 

tag = 02h, occurrence = 1 
valueOffset = 
compareBuffer . length = 12 
compareOf f set = 
compareLength = 2 


Result is OOh 




24 


Initialise compareBuffer 

compareBuffer = 01 02 ... C4 








Successful call (with tag B3h) 

tag = B3h, occurrence = 1 
valueOffset = 
compareBuffer . length = 00C4 
compareOf f set = 


Result is OOh 
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compareLength = 00C4 






25 


Successful call, findAndCompareValue with 
length =0 

DstBuffer. length = C4 
DstOffset = C4 
DstLength = 


Result of findAndCompareValueO 
isOOh 





6.2.4.17.4 



Test Coverage 



CRR number 


Test case number 


N1 


12 


N2 


14 


N3 


13, 17,20,21,25 


N4 


19,15 


N5 


16, 18,22 


N6 


23,24 


P1 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


P4 


11 


C1 


Does not apply for 
EnvelopeHandler 



6.2.5 Class EnvelopeResponseHandler 

6.2.5.1 sim.tookit.EnvelopeResponseHandler.getTheHandleM 

Test Area Reference: API_2_ERH_GTHD 

6.2.5.1.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public static EnvelopeResponseHandler getTheHandler ( ) 

throws ToolkitException 

Normal execution 

CRRNl: The method shall return the single system instance of the EnvelopeResponseHandler class. 

CRRN2: The EnvelopeResponseHandler is a Temporary JCRE Entry Point Object ( see Javacard 2.1 Runtime 
Environment (JCRE) Specification [12]) 

Parameter errors 

Context errors 

CRRCl: The method shall thrown ToolkitException (HANDLER_NOT_AV AIL ABLE) if the handler is busy. 

CRRC2: After the first invocation of the ProactiveHandler.send method the EnvelopeResponseHandler is no more 
available 



6.2.5.1.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test suite files 

API_2_ERH_GTHD_1 . scr 
API_2_ERH_GTHD_1 .j ava 
API_2_ERH_GTHD_1 .Idr 
API_2_ERH_GTHD_1 .clr 
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6.2.5.1.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


getTheHandler twice 


The returned objects shall be the 
same 




2 


Verify that getTheHandler returns an 
EnvelopeHandler 

getTheHandler 


The reference returned shall be an 

EnvelopeResponseHandler 

(checkcast) 




3 


Verify the returned value is not null 

getTheHandler 


The reference returned shall not be 
null. 




4 


getTheHandler, then send a proactive 
command, and then, appendTLV 


ToolkitException 
HANDLER_NOT_AVAILABLE is 
thrown 





6.2.5.1.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3 


N2 


To be checked in 

Framework tests and 

insert here cross 

reference 


CI 


To be checked in 

Framework tests and 

insert here cross 

reference 


C2 


4 



6.2.5.2 sim.tookit.EnvelopeResponseHandler.posM 

Test Area Reference:API_2_ERH_POSTB 

6.2.5.2.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public void post (byte statusType) 
throws ToolkitException 

Normal execution 

CRRNl: When the method is called, the toolkit applet can continue it's processing (e.g. prepare a proactive 
command). 

CRRN2: The byte statusType is SWl of the status. 

CRRN3: If the send method is called after a post method, the posted data are the first sent to the ME. 

CRRN4: The SIM Toolkit Framework shall take the optional Application Data posted by the triggered toolkit applet 
if present, secure and send the response packet the SIM Toolkit Framework will return the response APDU 
defined by the toolkit applet. 

Parameter error 

Context errors 

CRRCl: The method shall thrown ToolkitException (HANDLER_NOT_AVAILABLE) if the handler is busy. 

6.2.5.2.2 Test suite files 

Test Script: API_2_ERH_POSTB_l.scr 

All SMS PP sent to the applet are not securedwith SPI = 0800 
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Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.2.3 



API_2_ERH_POSTB_l .Java 
API_2_ERH_POSTB_l .Idr 
API 2 ERH POSTB l.clr 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


getTheHandler and then post 

(the handler is empty) 




9000 


2 


Fill the handler ( appendTLV to have bytes 

in it ) and then post data with status 
9F 




9FFD data are retrieved with GET 
RESPONSE command 


3 


Verify that after a post the handler is no 
more available 

appendTLV, post and then appendTLV 


ToolkitException 
HANDLER_NOT_AVAILABL 
E is thrown on the second 
appendTLV 




4 


construct the response (appendTLV with 

0x10 data) and post it with status 9E and 

then send a display text 




9E1 2 and posted data retrieved by a 
GET RESPONSE with status 91 1 3 
and display text retrieved by a FETCH 


5 


Verify that it is possible to send a proactive 
command after a post 

getTheHandler and post , then send a 
display text 




91 13 and display text is retrieved by 
a FETCH 


6 


Verify it is not possible to post after a 
proactive command 

getTheHandler, appendTLV, send a 
display text, post. 


ToolkitException 
HANDLER_NOT_AVAILABL 
E is thrown 




7 


Verify that the handler is no more available 
after a post 

getTheHandler, appendTLV, post with 
status 9E, post with status 9F 


ToolkitException 
HANDLER_NOT_AVAILABL 
E is thrown 


9E1 2 and posted data retrieved by a 
GET RESPONSE 



6.2.5.2.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,4,7 


N2 


1,2,4,7 


N3 


4,5 


N4 


To be checked in 

Framework tests and 

insert here cross 

reference 


CI 


6 



6.2.5.3 sim.tookit.EnvelopeResponseHandler.postAsBERTLV_1 

Test Area Reference:API_2_ERH_P0STBB 

6.2.5.3.1 Conformance Requirement 

The method with following header shall be compliant to its definition in the API. 

public void postAsBERTLV (byte statusType, 

byte tag) 
throws ToolkitException 

Normal execution 

CRRNl: When the method is called, the toolkit applet can continue it's processing (e.g. prepare a proactive 
command) the SIM Toolkit Framework will return the response APDU defined by the toolkit applet. 

CRRN2: The byte statusType is SWl of the status 

CRRN3: If the send method is called after a postAsBERTLV method, the posted data are the first sent to the ME. 
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CRRN4: The byte tag is the BER Tag at the beginning of the simple TLV list. 

Parameter errors 

Context errors 

CRRCl: The method shall thrown ToolkitException (HANDLER_NOT_AVAILABLE) if the handler is busy. 

6.2.5.3.2 Test suite files 

Specific triggering: Call control 

Test Script: 

Test Applet: 

Load Script: 

Clean-up Script: 



API_2_ERH_POSTBB_l .scr 
API_2_ERH_POSTBB_l .Java 
API_2_ERH_POSTBB_l .Idr 
API_2_ERH_POSTBB_l .clr 



6.2.5.3.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


getTheHandler and then postAsBERTLV 

(the handler is empty) 




9F02 data are retrieved with 

GET RESPONSE command, 

the tag shall be 33 and the 

length is 00 


2 


Fill the handler and then postAsBERTLV 
the data with status 9F, and tag 33 




9FFF data are retrieved with 

GET RESPONSE command, 

the tag shall be 33 


3 


appendTLV, postAsBERTLV and then 
appendTLV 


ToolkitException 

HANDLER_NOT_AVAILABLE is 

thrown on the second appendTLV 




4 


construct the response (appendTLV with 

0x10 data) and postAsBERTLV it with 

status 9E, tag 75 and then send a display 

text 




9E14and posted data 

retrieved by a GET 

RESPONSE the tag shall be 

75 with status 9113 and 

display text retrieved by a 

FETCH 


5 


getTheHandler and postAsBERTLV, then 
send a display text 




9E02 and posted data 

retrieved by a GET 

RESPONSE the tag 33 (and 

the length 00) with status 

9113 and display text is 

retrieved by a FETCH 


6 


Verify it is not possible to postAsBERTLV 
after a proactive command 

getTheHandler, appendTLV, send a 
display text, postAsBERTLV. 


ToolkitException 

HANDLER_NOT_AVAILABLE is 

thrown on the postAsBERTLV 




7 


Verify that the handler is no more available 
after a postAsBERTLV 

getTheHandler, appendTLV (with data 
length = 0x10, postAsBERTLV with status 
9E, tag 56, postAsBERTLV with status 
9F, tag 28 


ToolkitException 

HANDLER_NOT_AVAILABLE is 

thrown on the second postAsBERTLV 


9E14and posted data 

retrieved by a GET 

RESPONSE the tag shall be 

56 with status 9000 



6.2.5.3.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,4,7 


N2 


1,2,4,7 


N3 


4,5 


N4 


2,4,7 


CI 


6 
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6.2.5.4 Method getLength 

Test Area Reference: API_2_ERH_GLEN 

6.2.5.4.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getLength () 

throws ToolkitException 

Normal execution 

CRRN 1 : returns the length in bytes of the TLV list. 

Parameter errors 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 



6.2.5.4.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.4.3 



Test Suite files 

API_2_ERH_GLEN_1 .scr 
API_2_ERH_GLEN_1 .Java 
API_2_ERH_GLEN_1 .Idr 
API_2_ERH_GLEN_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Clear the handler 

getLength ( ) 


Result of getLengthO is 




2 


appendTLV with length of 7 

getLength () 


Result of getLengthO is 9 




3 


Clear the handler and appendTLV with Length 
01253 

getLength () 


Result of getLengthO is 256 




4 


Build a 7Fh Envelope response handler 

getLength ( ) 


Result of getLengthO is 81 h 




5 


Build a 80h Envelope response handler 

getLength () 


Result of getLengthO is 83h 





6.2.5.4.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3,4,5 


CI 


Does not apply for 

Envelope response 

handler 



6.2.5.5 Method copy 

Test Area Reference: API_2_ERH_COPY_BSS 

6.2.5.5.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short copy (byte [] dstBuffer, 
short dstOffset, 
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short dstLength) 

throws Java . lang . NullPointerException, 

Java .lang . Array I ndexOut Of Bounds Except ion. 
Toolkit Except ion 

Normal execution 

CRRNl: copies the simple TLV list contained in the handler to the destination byte array. 
CRRN2: returns dstOffset + dstLength. 

Parameter errors 

CRRPl: if dstBuffer is null a NullPointerException is thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative, an 
ArraylndexOutOfBoundsException is thrown. 

CRRP3: if dstLength is greater than the length of the simple TLV List, an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException. OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AV AIL ABLE. 

6.2.5.5.3 Test Suite files 

Test Script: API_2_ERH_COPY_BSS_l.scr 

Test Applet: API_2_ERH_COPY_BSS_l.java 

Load Script: API_2_ERH_COPY_BSS_l.ldr 

Clean-up Script: API_2_ERH_COPY_BSS_l.clr 
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6.2.5.5.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


NULL as parameter to dstBuffer 


NullPointerException is thrown 




2 


appendTLV with value length of 7 








dstOffset > dstBuffer.length 

dstBuffer . length = 5 
dstOffset = 5 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


dstLength > dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength > dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


dstLength > length of the simple TLV list 

dstBuffer.length = 10 
dstOffset = 
dstLength = 10 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


Successful call, dstBuffer is the whole buffer 

dstBuffer.length = 9 
dstOffset = 
dstLength = 9 


Result of copyQ is 9 




9 


Compare the buffer 


Result of arrayCompareO is 




10 


Successful call, dstBuffer is part of a buffer 

dstBuffer.length = 15 
dstOffset = 3 
dstLength = 9 


Result of copyQ is 12 




11 


Compare the whole buffer 


Result of arrayCompareO is 




12 


Successful call, dstBuffer is part of a buffer 

dstBuffer.length = 15 
dstOffset = 3 
dstLength = 6 


Result of copyQ is 9 




13 


Compare the whole buffer 


Result of arrayCompareO is 




14 


Successful call, copy with length =0 

dstBuffer.length = 15 
dstOffset = 15 
dstLength = 


Result of copyO is 15 





6.2.5.5.4 



Test Coverage 



CRR number 


Test case number 


N1 


9, 11, 13 


N2 


8, 10, 12, 14 


PI 


1 


P2 


2, 3, 4, 5, 6 


P3 


7 


CI 


Does not apply for 

Envelope response 

handler 



6.2.5.6 Method findTLV 

Test Area Reference: API 2 ERH FINDBB 
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6.2.5.6.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte findTLV(byte tag, byte occurrence) 
throws ToolkitException 

Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of the TLV list (handler buffer): 

CRRNl: the method is successful if the required occurrence exists then the corresponding TLV becomes current. 

CRRN2: if the method is successful then it returns TLV_FOUND_CR_SET when Comprehension Required flag is 
set. 

CRRN3: if the method is successful then it returns TLV_FOUND_CR_NOT_SET when Comprehension Required 
flag is not set. 

CRRN4: if the required occurrence of the TLV element does not exist, the current TLV is no longer defined and 
TLV_NOT_FOUND is returned. 

CRRN5: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl : if an input parameter is not valid (e.g. occurrence = 0) an instance of ToolkitException shall be thrown. 
The reason code shall be ToolkitException BAD_INPUT_PARAMETER. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 



6.2.5.6.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.6.3 



Test Suite files 

API_2_ERH_FINDBB_l.scr 
API_2_ERH_FINDBB_l.java 
API_2_ERH_FINDBB_1 .Idr 
API_2_ERH_FINDBB_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


append the handler with TLVs: 

81 03 11 22 33 

82 02 99 77 








Invalid input parameter 

Occurrence = 


ToolkitException. BAD INPUT P 
ARAMETER is thrown 




2 










Search 1st TLV 

Tag = Olh 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




3 


Call the getValueLengthO method 


Result is 03h 




4 


Search 2nd TLV 

Tag = 02h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




5 


Call the getValueLengthO method 


Result is 02h 




6 


Select a TLV (tag 02h) 








Search a wrong tag 

Tag = 03h 
Occurrence = 1 


Result is TLV_NOT_FOUND 





£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



99 



ETSI TS 101 955 V7.1.0 (2001-06) 



7 


Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




8 


Search a tag with wrong occurrence 

Tag = Olh 
Occurrence = 2 


Result is TLV_NOT_FOUND 




9 


Call the getValueLengthO method 


Tooll<itException.UNAVAILABLE 
ELEIVIENT is thrown. 




10 


Append a TLV with tag=02h 








Search the TLV 

Tag = 02h 
Occurrence = 2 


Result is 
TLV_FOUND_CR_NOT_SET 




11 


Append a TLV with tag=04h 








Search the TLV 

Tag = 04h 
Occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 




12 


Search tag 81 h 

Tag = 81h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




13 


Search tag 84h 

Tag = 84h 
Occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 





6.2.5.6.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,5 


N2 


2,4 


N3 


10, 11 


N4 


6,7,8,9 


N5 


12, 13 


PI 


1 


CI 


Does not apply for 

Envelope response 

handler 



6.2.5.7 Method getValueLength 

Test Area Reference: API_2_ERH_GVLE 

6.2.5.7.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getValueLength ( ) 

throws ToolkitException 

Normal execution 

CRRNl: gets and returns the binary length of the value field for the last TLV element which has been found in the 
handler. 

Parameter errors 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 
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6.2.5.7.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.7.3 



Test Suite files 

API_2_ERH_GVLE_1 .scr 
API_2_ERH_GVLE_1 .Java 
API_2_ERH_GVLE_1 .Idr 
API_2_ERH_GVLE_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


appendTLV 02 02 02 02 
findTLV with TAG 03 








getValueLengthO 


ToolkitException.UNAVAILABLE 
_ELEMENT is thrown 




2 


appendTLV with TAG OD and length 00 








Search TLV ODh 








getValueLength ( ) 


Result is OOh 




3 


Clear the handler and append TLV with TAG 
OD and length 02 








Search TLV ODh 








getValueLength ( ) 


Result is 02h 




4 


Clear the handler and append TLV with TAG 
OD and length 0x7F 








Search TLV ODh 








getValueLengthO 


Result is 7Fh 




5 


Clear the handler and append TLV with TAG 
OD and length 0x80 








Search TLV ODh 








getValueLength ( ) 


Result is 80h 




6 


Clear the handler and append TLV with TAG 
OD and length OxFI 








Search TLV ODh 








getValueLength ( ) 


Result is Flh 





6.2.5.7.4 



Test Coverage 



CRR number 


Test case number 


N1 


2, 3, 4, 5, 6 


C1 


Does not apply for 

EnvelopeResponseHandl 

er 


C2 


1 



6.2.5.8 Method getValueByte 

Test Area Reference: API_2_ERH_GVBYS 

6.2.5.8.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getValueByte (short valueOffset) 
throws ToolkitException 

Normal execution 

CRRNl: Gets a byte from the last TLV element which has been found in the handler and returns its value (1 byte). 
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Parameter errors 

CRRPl: if valueOffset is out of the current TLV an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.5.8.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.8.3 



Test Suite files 

API_2_ERH_GVB YS_1 .scr 
API_2_ERH_GVB YS_1 .Java 
API_2_ERH_GVB YS_1 .Idr 
API_2_ERH_GVB YS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


appendTLV 82 02 81 82, appendTLV 81 03 1 1 

22 FE 

fIndTLV with TAG 03 








getValueByte (0) 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




2 


Search TLV 01 h 








getValueByte (3) 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




3 


Search TLV 01 h 








getValueByte (2) 


Result is FEh 




4 


Search TLV 02h 








getValueByte (0) 


Result is 81 h 




5 


appendTLV with TAG OD, Length 0x7E, Value: 
00, 01,..., 7D 








getValueByte (7D) 


Result is 7Dli 




6 


clear the handler, appendTLV with TAG OD, 
Length 0x80, Value: 00, 01, ..., 7F 








getValueByte (7E) 


Result is 7Eh 




7 


getValueByte (7F) 


Result is 7Fh 




8 


clear the handler, appendTLV with TAG OD, 
Length OxFI, Value: 00, 01, ..., FO 








getValueByte (FO) 


Result is FOh 





6.2.5.8.4 



Test Coverage 



CRR number 


Test case number 


N1 


3, 4, 5, 6, 7, 8 


P1 


2 


C1 


Does not apply for 

EnvelopeResponseHandl 

er 


C2 


1 
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6.2.5.9 Method copyValue 

Test Area Reference: API_2_ERH_CPYVS_BSS 

6.2.5.9.1 Conformance requirement 

The method with following header shall be compliant with its definition in the API. 

public short copyValue (short valueOffset, 

byte[] dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: copies a part of the last TLV element which has been found, into a destination, buffer. 
CRRN2: returns dstOffset + dstLength. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException is thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException is thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 

6.2.5.9.3 Test Suite files 

Test Script: API_2_ERH_CPYVS_BSS_l.scr 

Test Applet: API_2_ERH_CPYVS_BSS_Ljava 

Load Script: PI_2_ERH_CPYVS_BSS_Lldr 

Clean-up Script: PI_2_ERH_CPYVS_BSS_Lclr 
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6.2.5.9.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 
Select a TLV 








copyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


appendTLV with TAG: OD and length 16 
Select Text String TLV 








dstOffset > dstBuffer.length 

dstBuffer . length = 5 
dstOffset = 5 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


clear the handler, appendTLV with TAG: OD 

and length 6 

Select Text String TLV 








valueOffset > Text String Length 

valueOffset = 6 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > Text String length 

valueOffset = 
dstBuffer.length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > Text String length 

valueOffset = 2 
dstBuffer.length = 15 
dstOffset = 
dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Initialise the handler 








copyValue () 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




12 


Clear the handler, appendTLV with TAG: OD 

and value: 04 00 01 ...OF 

Select Text String TLV 








Successful call 

valueOffset = 
dstBuffer.length = 17 
dstOffset = 
dstLength = 17 


Result of copyValueO is 17 




13 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




14 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

valueOffset = 2 
dstBuffer.length = 20 
dstOffset = 3 
dstLength = 12 


Result of copyValueO is 15 
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15 


Compare buffer 

buffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 


Result is OOh 




16 


Successful call, copyValue with length =0 

dstBuffer. length = 20 
dstOffset = 20 
dstLength = 


Result of copyValueO is 20 





6.2.5.9.4 



Test Coverage 



CRR number 


Test case number 


N1 


13,15 


N2 


12, 14, 16 


PI 


1 


P2 


2,3,4,5,6 


P3 


7,8,9, 10 


CI 


Does not apply for 

EnvelopeResponseHandl 

er 


C2 


11 



6.2.5.10 Method compareValue 

Test Area Reference: API_2_ERH_CPRVS_BSS 



6.2.5.10.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public byte compareValue (short valueOffset, 

byte[] compareBuf fer, 
short compareOf f set, 
short compareLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
Toolkit Except ion 

Normal execution 

Compares the last found TLV element with a buffer: 

CRRNl: returns if identical. 

CRRN2: returns -1 if the first miscomparing byte in simple TLV List is less than that in compareBuffer. 

CRRN3: returns 1 if the first miscomparing byte in simple TLV List is greater than that in compareBuffer. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if compareLength 
is negative ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 
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CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.5.10.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.10.3 



Test Suite files 

API_2_ERH_CPRVS_BSS_1 .scr 
API_2_ERH_CPRVS_BSS_1 .Java 
API_2_ERH_CPRVS_BSS_1 .Idr 
API_2_ERH_CPRVS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 
Select a TLV 








compareValueO with a null compareBuffer 


NullPointerException is thrown 




2 


appendTLV with TAG: OD and length 16 
Select Text String TLV 








compareOffset > compareBuffer.length 

compareBuff er . length = 5 
compareOffset = 5 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 5 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


compareLength >compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 
>compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


appendTLV with TAG: OD and length 6 
Select Text String TLV 








valueOffset > Text String Length 

valueOffset = 6 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


compareLength > Text String length 

valueOffset = 
compareBuffer.length = 15 
compareOffset = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > Text String 
length 

valueOffset = 2 
compareBuffer.length = 15 
compareOffset = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Initialise the handler 








compareValue () 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




12 


appendTLV with TAG: OD and value: 04 00 01 
...OF 
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Select Text String TLV 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








Compare buffers 

valueOffset = 
compareOf f set = 
compareLength = 17 


Result is OOh 




13 


Initialise compareBuffer 

compareBuffer = 
04 00 01 02 03 

04 05 06 07 08 

05 OA OB OC OD 
OE 10 








Compare buffers with same parameters 


Result is -1 




14 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result is +1 




15 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers 

valueOffset = 2 
compareOf f set = 3 
compareLength = 12 


Result is OOh 




16 


Initialise compareBuffer 

compareBuffer = 
55 55 55 02 01 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




17 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OA OD 
55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




18 


Successful call, compareValue with length =0 

compareBuf fer . length = 15 
compareOf f set = 15 
compareLength = 


Result of compareValueO is 





6.2.5.10.4 



Test Coverage 



CRR number 


Test case number 


N1 


12, 15, 18 


N2 


13, 16 


N3 


14, 17 


PI 


1 


P2 


2,3,4,5,6 


P3 


7,8,9, 10 


CI 


Does not apply for 

EnvelopeResponseHandl 

er 


C2 


11 



6.2.5.1 1 Method findAndCopyValue(byte tag, byteQ dstBuffer, short valueOffset) 

Test Area Reference: API_2_ERH_FACYB_BS 
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6.2.5.11.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte[] dstBuffer, 

short dstOffset) 
throws Java . lang . NullPointerException, 
Java .lang . ArraylndexOutOfBoundsException, 

Toolkit Except ion 

Normal execution 

CRRNl: looks for the first occurrence of a TLV element from the beginning of a TLV list and copy its value into a 
destination buffer. 

CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + length of the 
copied value is returned. 

CRRN4: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException shall be thrown. 

CRRP2: if dstOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitExceptionHANDLER_NOT_AVAILABLE. 



6.2.5.11.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.11.3 



Test Suite files 

API_2_ERH_FACYB_BS_1 .scr 
API_2_ERH_FACYB_BS_1 .Java 
API_2_ERH_FACYB_BS_1 .Idr 
API_2_ERH_FACYB_BS_1 .ck 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








findAndCopyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


appendTLV with TAG: OD and length 16 
Select Text String TLV 








dstOffset > dstBuffer.length 

tag = ODh 

dstBuffer.length = 20 
dstOffset = 20 


ArraylndexGutOfBoundsExceptio 
n is thrown 




3 


dstOffset < 

dstBuffer.length = 20 
dstOffset = -1 


ArraylndexGutOfBoundsExceptio 
n is thrown 




4 


dstOffset + length >dstBuffer.length 

dstBuffer.length = 20 
dstOffset = 5 


ArraylndexGutOfBoundsExceptio 
n is thrown 




5 


length > dstBuffer.length 

dstBuffer.length = 15 
dstOffset = 


ArraylndexGutOfBoundsExceptio 
n is thrown 
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6 


Clear the handler, appendTLV with TAG 02 
and Length 02 








Select a TLV (tag 02h) 








f indAndCopyValue () 
tag = 03h 


ToolkltException.UNAVAILABLE 
ELEMENT is thrown 






Call the getValueLengthO method 


ToolkltException.UNAVAILABLE 
ELEIVIENT is thrown. 




7 


appendTLV with TAG: OD and value: 04 00 01 
...OF 








Successful call 

Tag = ODh 

dstBuffer. length = 17 

dstOffset = 


Result of fincJAndCopyValueO is 
17 




8 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




9 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

dstBuffer .length = 20 
dstOffset = 2 


Result of findAndCopyValueO is 
19 




10 


Compare buffer 

buffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 


Result is OOh 




11 


clear the handler, appendTLV with TAG: OD 
and value: 04 00 01 ... OF 








append a 2"" Text String TLV 








Successful call 

tag = ODh 

dstBuffer. length = 17 

dstOffset = 


Result of findAndCopyValueO is 
17 




12 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




13 


Clear the handler, appendTLV with TAG: OD 
and value: 04 00 01 ...OF 








Successful call (with tag 8Dh) 

tag = 8Dh 

dstBuffer .length = 17 

dstOffset = 


Result of findAndCopyValueO is 
17 




14 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




15 


Append tag OFh 

buffer = 00 01 ... OF 








Successful call (with tag 8Fh) 

tag = 8Fh 

dstBuffer .length = 16 

dstOffset = 


Result of findAndCopyValueO is 
16 




16 


Compare buffer 

buffer = 00 01 ... OF 


Result is OOh 





6.2.5.11.4 



Test Coverage 



CRR number 


Test case number 


N1 


8, 10, 12 


N2 


6 


N3 


7, 9, 11 


N4 


13, 14, 15, 16 


PI 


1 


P2 


2, 3, 4, 5 


CI 


Does not apply for 

EnvelopeResponseHandl 

er 
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6.2.5.12 Method findAndCopyValue(byte tag, byte occurrence, short valueOffset, byte[] 
dstBuffer, short dstOffset, short dstLength) 



Test Area Reference: API 2 ERH FACYBBS BSS 



6.2.5.12.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte occurrence, 
short valueOffset, 
byte[] dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: looks for the indicated occurrence of a TLV element from the beginning of a TLV list and copy its value 
into a destination buffer. 

CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + dstLength is 
returned. 

CRRN4: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException shall be thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 



6.2.5.12.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_ERH_FACYBBS_BSS_1 .scr 
API_2_ERH_FACYBBS_BSS_1 .Java 
API_2_ERH_FACYBBS_BSS_1 .Idr 
API_2_ERH_FACYBBS_BSS_1 .clr 



6.2.5.12.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








fincJAndCopyValueQ with a null dstBuffer 


NullPointerException is thrown 




2 


appendTLV with TAG: OD and length 16 








dstOffset > dstBuffer.length 

tag = ODh, occurrence = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 
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valueOffset = 
dstBuffer .length = 5 
dstOffset = 5 
dstLength = 1 






3 


dstOffset < 

dstBuffer . length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


dstLength >dstBuffer.length 

dstBuffer . length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




5 


dstOffset + dstLength >dstBuffer.length 

dstBuffer .length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer .length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


appendTLV with TAG: OD and length 6 








valueOffset > Text String Length 

tag = ODh, occurrence = 1 
valueOffset = 6 
dstBuffer. length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
dstBuffer. length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > Text String length 

valueOffset = 
dstBuffer .length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > Text String length 

valueOffset = 2 
dstBuffer .length = 15 
dstOffset = 
dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


clear the handler, appendTLV with TAG 02 
and Length 02 








Select a TLV (tag 02h) 








f IndAndCopyValue () 
tag = ODh 
occurrence = 2 


ToolkitException.UNAVAILABLE 
_ELEMENT is thrown 






Call the getValueLength method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




12 


clear the handler and appendTLV with TAG: 
OD and value: 04 00 01 ... OF 








Successful call 

tag = ODh, occurrence = 1 
valueOffset = 
dstBuffer. length = 17 
dstOffset = 
dstLength = 17 


Result of findAndCopyValueO is 
17 




13 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




14 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

tag = ODh, occurrence = 1 
valueOffset = 2 
dstBuffer. length = 20 
dstOffset = 3 
dstLength = 12 


Result of findAndCopyValueO is 
15 




15 


Compare buffer 

buffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 


Result is OOh 
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16 


Append a Text String TLV 

tag = OD 

buffer = 00 11 22 33 44 55 (no specific 

DCS byte) 








Successful call 

tag = ODh, occurrence = 1 
valueOffset = 
dstBuffer. length = 20 
dstOffset = 
dstLength = 17 


Result of fincJAndCopyValueO is 
17 




17 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOli 




18 


Successful call 

tag = ODh, occurrence = 2 
valueOffset = 
dstBuffer . length = 6 
dstOffset = 
dstLength = 6 


Result of findAndCopyValueO is 
6 




19 


Compare buffer 

buffer = 00 11 22 33 44 55 


Result is OOh 




20 


clear the handler and appendTLV with TAG: 
OD and value: 04 00 01 ... OF 








Successful call (with tag BDh) 

tag = 8Dh 
occurrence = 1 
valueOffset = 
dstBuffer. length = 17 
dstOffset = 
dstLength = 17 


Result of findAndCopyValue () is 
17 




21 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




22 


Append tag OFh 

buffer = 00 01 ... OF 








Successful call (with tag 8Fh) 

tag = 8Fh 
occurrence = 1 
valueOffset = 
dstBuffer .length = 16 
dstOffset = 
dstLength =16 


Result of findAndCopyValue () is 
16 




23 


Compare buffer 

buffer = 00 01 ... OF 


Result is OOh 




24 


Successful call, findAndCopyValue with 
length =0 

dstBuffer .length = 16 
dstOffset = 16 
dstLength = 


Result of findAndCopyValue () is 
16 





6.2.5.12.4 



Test Coverage 



CRR number 


Test case number 


N1 


13, 15, 17, 19 


N2 


11 


N3 


12, 14, 16, 18,24 


N4 


20,21,22,23 


PI 


1 


P2 


2, 3, 4, 5, 6 


PS 


7,8,9, 10 


CI 


Does not apply for 

EnvelopeResponseHandl 

er 



6.2.5.13 Method findAndCompareValue(byte tag, byte[] compareBuffer, short 
compareOffset) 



Test Area Reference: API 2 ERH FACRB BS 
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6.2.5.13.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte[] compareBuf fer, 
short compareOf f set ) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

Looks for the first occurrence of a TLV element from beginning of a TLV list and compare its value with a buffer: 

CRRNl: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN2: if the method is successful then the corresponding TLV becomes current. 

CRRN3: if identical returns 0. 

CRRN4: if the first miscomparing byte in simple TLV is less than that in compareBuffer returns -1. 

CRRN5: if the first miscomparing byte in simple TLV is greater than that in compareBuffer returns 1. 

CRRN6: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be 
thrown. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AV AIL ABLE. 



6.2.5.13.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.13.3 



Test Suite files 

API_2_ERH_FACRB_BS_1 .scr 
API_2_ERH_FACRB_BS_1 .Java 
API_2_ERH_FACRB_BS_1 .Idr 
API_2_ERH_FACRB_BS_1 .ck 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








findAndCompareVaiueQ with a null dstBuffer 


NullPointerException is thrown 




2 


appendTLV with TAG: OD and length 16 








compareOffset > compareBuffer.length 

tag = ODh 

compareBuffer.length = 20 
compareOffset = 20 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


compareOffset < 

compareBuffer.length = 20 
compareOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


compareOffset + length > 
compareBuffer.length 

compareBuffer.length = 20 


ArraylndexOutOfBoundsExceptio 
n is thrown 
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compareOf f set = 5 






5 


length > compareBuffer.length 

compareBuf fer . length = 15 
compareOf f set = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


clear the handler, appendTLV with TAG 02 
and Length 02 








Select a TLV (tag 02h) 








f indAndCompareValue () 
tag = 03h 


Tooll<itException.UNAVAILABLE 
ELEIVIENT is thrown 




7 


Verify current TLV 

getValueLength ( ) 


Tooll<itException.UNAVAILABLE 
ELEIVIENT is thrown. 




8 


clear the handler and appendTLV with TAG: 
OD and value: 04 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








Compare buffers 

tag = ODh 
compareOf f set = 


Result Is OOh 




9 


Verify current TLV 

getValueLength ( ) 


Result is 17 




10 


Initialise compareBuffer 

compareBuffer = 
04 00 01 ... 10 








Compare buffers with same parameters 


Result is -1 




11 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result is +1 




12 


Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOf f set = 2 


Result is OOh 




13 


append a Text String TLV 

tag = ODh 

buffer = 00 11 22 33 44 55 








Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOf f set = 2 


Result is OOh 




14 


Initialise compareBuffer 

compareBuffer = 
55 55 04 01 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOffset = 2 


Result is -1 




15 


Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OD 10 55 








Compare buffers 

compareOffset = 2 


Result is +1 




16 


clear the handler and appendTLV with TAG: 
OD and value: 04 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 04 00 01 ... OF 








Successful call (with tag 8Dh) 

tag = 8Dh 

compareBuffer.length = 17 
compareOffset = 


Result is OOh 
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17 


Append tag OFh 

buffer = 00 01 ... OF 








Initialise compareBuffer 

compareBuf fer = 00 01 ... OF 








Successful call (with tag 8Fh) 

tag = 8Fh 

compareBuf fer . length = 16 

compareOf f set = 


Result is OOh 





6.2.5.13.4 



Test Coverage 



CRR number 


Test case number 


N1 


6,7 


N2 


7,9 


N3 


8, 13, 12 


N4 


10, 14 


N5 


11, 15 


N6 


17, 16 


PI 


1 


P2 


2, 3, 4, 5 


CI 


Does not apply for 

Envelope response 

handler 



6.2.5.14 Method findAndCompareValue(byte tag, byte occurrence, short valueOffset, 
byteQ compareBuffer, short compareOffset, short compareLength) 



Test Area Reference: API_2_ERH_FACRBBS_BSS 



6.2.5.14.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte occurrence, 
short valueOffset, 
byte[] compareBuffer, 
short compareOffset, 
short compareLength) 
throws Java . lang . NullPointerException, 

Java .lang . Array I ndexOut Of Bounds Except ion. 
Toolkit Except ion 

Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of a TLV list and compare its value with a 
buffer: 

CRRNl: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN2: if the method is successful then the corresponding TLV becomes current. 

CRRN3: if identical is returned. 

CRRN4: if the first miscomparing byte in simple TLV is less than that in compareBuffer -1 is returned. 

CRRN5: if the first miscomparing byte in simple TLV is greater than that in compareBuffer 1 is returned 

CRRN6: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 
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CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if compareLength 
is negative ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, compareLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

CRRP4: if an input parameter is not valid (e.g. occurrence = 0) an instance of ToolkitException shall be thrown. The 
reason code shall be ToolkitException BAD_INPUT_PARAMETER. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AV AIL ABLE. 



6.2.5.14.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.14.3 



Test Suite files 

API_2_ERH_FACRBBS_BSS_1 .scr 
API_2_ERH_FACRBBS_BSS_1 .Java 
API_2_ERH_FACRBBS_BSS_1 .Idr 
API_2_ERH_FACRBBS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








findAndCompareVaiueQ with a null 
compareBuffer 


NullPointerException is thrown 




2 


clear the handler and appendTLV with TAG: 
OD and value: 04 00 01 ... OF 








compareOffset > compareBuffer.length 

tag = ODh, occurrence = 1 
valueOffset = 
compareBuffer.length = 5 
compareOffset = 5 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 5 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


compareLength >compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 
>compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


clear the handler and appendTLV with TAG 
and length of 6 








valueOffset > Text String Length 

tag = ODh, occurrence = 1 
valueOffset = 6 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 
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9 


compareLength > Text String length 

valueOffset = 
compareBuf fer . length = 15 
compareOf f set = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > Text String 
length 

valueOffset = 2 
compareBuf fer . length = 15 
compareOf f set = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Invalid parameter 

occurrence = 


ToolkitException.BAD INPUT P 
ARAIVIETER is thrown 




12 


appendTLV with TAG 02 and length 02 








Select a TLV (tag 02h) 








f indAndCompareValue () 
tag = ODh 
occurrence = 2 


ToolkitException.UNAVAILABLE 
_ELEIVIENT is thrown 




13 


Verify current TLV 

getValueLength ( ) 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown. 




14 


clear the handler and appendTLV with TAG: 
OD and value: 04 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








findAndCompareValueQ 

tag = ODh, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 17 


Result is OOh 




15 


Verify current TLV 

getValueLength ( ) 


Result is 17 




16 


Initialise compareBuffer 

compareBuffer = 
04 00 01 ... 10 








Compare buffers with same parameters 


Result is -1 




17 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result is +1 




18 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers 

valueOffset = 2 
compareOf f set = 3 
compareLength = 12 


Result is OOh 




19 


Initialise compareBuffer 

compareBuffer = 
55 55 55 02 01 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




20 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OA OD 
55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




21 


append a Text String TLV 

tag = ODh 

buffer = 00 11 22 33 44 55 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








findAndCompareValueQ 

tag = ODh, occurrence = 1 
valueOffset = 


Result is OOh 
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compareOf f set = 
compareLength = 17 






22 


Initialise compareBuffer 

compareBuff er = 
00 11 22 33 44 55 








findAndCompareValueQ 

tag = ODh, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 6 


Result Is OOh 




23 


Initialise compareBuffer 

compareBuffer = 
00 11 22 33 44 66 








findAndCompareValueQ 

tag = ODh, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 6 


Result Is -1 




24 


clear the handler and appendTLV with TAG: 
CD and value: 04 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 04 00 01 ... OF 








Successful call (with tag 8Dh) 

tag = 8Dh, occurrence = 1 
valueOffset = 
compareBuffer . length = 17 
compareOf f set = 
compareLength = 17 


Result is OOh 




25 


Append tag OFh 

buffer = 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 00 01 ... OF 








Successful call (with tag BFh) 

tag = 8Fh, occurrence = 1 
valueOffset = 
compareBuffer . length =16 
compareOf f set = 
compareLength = 16 


Result is OOh 




26 


Successful call, findAndCompareValue with 
length =0 

CompareBuff er . length = 16 
compareOf f set = 16 
compareLength = 


Result of findAndCompareValue 
is 00 





6.2.5.14.4 



Test Coverage 



CRR number 


Test case number 


N1 


12,13 


N2 


15,13 


N3 


14, 18, 22,21,26 


N4 


16, 19,23 


N5 


17, 19 


N6 


25,24 


P1 


1 


P2 


2,3,4,5,6 


P3 


7,8,9, 10 


P4 


11 


C1 


Does not apply for 

EnvelopeResponseHandl 

er 



6.2.5.15 Method appendArray 

Test Area Reference: API 2 ERH APDA BSS 
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6.2.5.15.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

void appendArray (byte [ ] buffer, short offset, short length) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: appends a buffer into the EditHandler buffer 
CRRN2: a successful append does not modify the TLV selected 

6.2.5.15.2.2 Parameters error 

CRRPl: if buffer is null, a java.lang.NullPointerException is thrown 

CRRP2: if offset or length or both would cause access outside the array bounds, or if length is negative, a 
java.lang. ArraylndexOutOfBoundsException is thrown. 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 



6.2.5.15.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.15.3 



Test suite files 

API_2_ERH_APDA_BSS_1 .scr 
API_2_ERH_APDA_BSS_1 .Java 
API_2_ERH_APDA_BSS_1 .Idr 
API_2_ERH_APDA_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Null buffer 


NullPointerException is thrown 




2 


offset > buffer.length 


ArraylndexOutOfBoundsExceptio 






buf fer . length = 5 


n is thrown 






offset = 5 








length = 1 






3 


offset < 


ArraylndexOutOfBoundsExceptio 






buffer.length = 5 


n is thrown 






offset = -1 








length = 1 






4 


length > buffer.length 


ArraylndexOutOfBoundsExceptio 






buffer.length = 5 


n is thrown 






offset = 








length = 6 






5 


offset + length > buffer.length 


ArraylndexOutOfBoundsExceptio 






buffer.length = 5 


n is thrown 






offset = 3 








length = 3 






6 


length < 


ArraylndexOutOfBoundsExceptio 






buffer.length = 5 


n is thrown 






offset = 








length = -1 






7 


Handler overflow 


ToolkitException. HANDLER OV 






buffer.length = 256 


ERFLOW is thrown 






offset = 








length = 256 
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8 


append the handler with TLVs: 

81 03 11 22 33 

82 02 99 77 








findTLV 0x81 








Successful call 

buffer = FF FE ... F8 
offset = 
length = 8 








Verify Current TLV: Call getValueLengthQ 


Result is 03h 




9 


Clear the handler 








Successful call 

buffer = FF FE ... F8 
offset = 
length = 8 








Call copyO method 








Compare handler 

compareBuf fer = FF FE ... F8 


Result is OOh 




10 


Successful call 

buffer = 00 01 ... 07 
offset = 2 
length = 6 








Call copvO method 








Compare handler 

compareBuffer = FF FE ... F8 02 03 ... 07 


Result is OOh 




11 


Successful call 

buffer = 11 22 ... 88 
offset = 2 
length = 4 








Call copyO method 








Compare handler 

compareBuffer = FF FE ... F8 02 03 ... 07 33 
44 55 66 


Result is OOh 





6.2.5.15.4 



Test Coverage 



CRR number 


Test case number 


N1 


9, 10, 11 


N2 


8 


N3 




PI 


1 


P2 


2, 3, 4, 5, 6 


CI 


7 


C2 


Does not apply for 

EnvelopeResponseHandl 

er 



6.2.5.1 6 Method appendTLV(byte tag, byte value) 

Test Area Reference: API_2_ERH_APTLBB 

6.2.5.16.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

voici appendTLV (byte tag, byte value) 
throws ToolkitException 

Normal execution 

CRRNl: Appends a TLV element to the current TLV list (1-byte element). 

CRRN2: A successful append does not modify the TLV selected. 
Parameters error 

None 
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Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER NOT AVAILABLE 



6.2.5.16.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.16.3 



Test suite files 

API_2_ERH_APTLBB_Lscr 
API_2_ERH_APTLBB_Ljava 
API_2_ERH_APTLBB_Lldr 
API_2_ERH_APTLBB_Lclr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Call appendArrayO 

length = 251 








Handler Overflow: Call the appendlLVQ 
method 


ToolkitException. HANDLER OV 
ERFLOW is thrown 




2 


append the handler with TLVs: 

81 03 11 22 33 

82 02 99 77 








Select Command Details TLV 








Call the appendTLVQ method 








Verify Current TLV: Call getValueLengthQ 


Result is 03h 




3 


Clear the handler 








Successful call 

tag = 84h 
value = OOh 








Call copyO method 








Compare handler 

compareBuffer = 84 01 00 


Result is OOh 




4 


Successful call 

tag = Olh 
value = FEh 








Call copyO method 








Compare handler 

compareBuffer = 84 01 00 01 01 FE 


Result is OOh 





6.2.5.16.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,4 


N2 


2 


C1 


1 


C2 


Does not apply for 

EnvelopeResponseHandl 

er 



6.2.5.1 7 Method appendTLV(byte tag, byte valuel , byte value2) 

Test Area Reference: API_2_ERH_APTLBBB 

6.2.5.17.1 Conformance requirements: 

The method with following header shall be compliant to its definition in the API. 

void appendTLV (byte tag, byte valuel, byte value2) 
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throws ToolkitException 

Normal execution 

CRRNl: Appends a TLV element to the current TLV list (2-byte element). 

CRRN2: A successful append does not modify the TLV selected. 
Parameters error 

None 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 



6.2.5.17.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.17.3 



Test suite files 

API_2_ERH_APTLBBB_1 .scr 
API_2_ERH_APTL BBB_Ljava 
API_2_ERH_APTL BBB_Lldr 
API_2_ERH_APTLBBB_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Call the appendlLV with length of 253 








Handler Overflow: Call the appendTLVQ 
method 


ToolkitException. HANDLER OV 
ERFLOW is thrown 




2 


clear the handler, append the handler with 
TLVs: 

81 03 11 22 33 

82 02 99 77 








Select Command Details TLV 








Call the appendTLVO method 








Verify Current TLV: Call getValueLengthQ 


Result is 03h 




3 


Clear the handler 








Successful call 

tag = 84h 
valuel = OOh 
value2 = Olh 








Call copyO method 








Compare handler 

compareBuf fer = 84 02 00 01 


Result is OOh 




4 


Successful call 

tag = Olh 
valuel = FEh 
value2 = FDh 








Call copvO method 








Compare handler 

compareBuffer = 84 02 00 01 01 02 FE FD 


Result is OOh 
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6.2.5.17.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,4 


N2 


2 


C1 


1 


C2 


Does not apply for 

EnvelopeResponseHandl 

er 



6.2.5.18 Method appendTLV(byte tag, byte[ ] value, short valueoffset, short valuelength) 

Test Area Reference: API_2_ERH_APTLB_BSS 



6.2.5.18.1 



Conformance requirement: 



The method with following header shall be compliant to its definition in the API. 

void appendTLV (byte tag, 

byte [ ] value, 
short valueoffset, 
short valuelength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
Toolkit Except ion 

Normal execution 

CRRNl: Appends a TLV element to the current TLV list (byte-array element). 

CRRN2: A successful append does not modify the TLV selected. 
Parameters error 

CRRPl: if value is null, a Java. lang. NullPointerException is thrown 

CRRP2: if valueoffset or valuelength or both would cause access outside the array bounds, or if length is negative, a 
java.lang. ArraylndexOutOfBoundsException is thrown. 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 

CRRC3: if valuelength is greater than 255, a ToolkitException is thrown with reason code 
BAD_INPUT_PARAMETER 



6.2.5.18.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test suite files 

API_2_ERH_APTLB_BSS_l.scr 
API_2_ERH_APTLB_BSS_l.java 
API_2_ERH_APTLB_BSS_1 .Idr 
API_2_ERH_APTLB_BSS_1 .clr 
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6.2.5.18.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Null value 


NullPointerException is thrown 




2 


valueOffset > value.length 

value. length = 5 
valueOffset = 5 
valueLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


valueOffset < 

value.length = 5 
valueOffset = -1 
valueLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


valueLength > value.length 

value.length = 5 
valueOffset = 
valueLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


valueOffset + valueLength > value.length 

value.length = 5 
valueOffset = 3 
valueLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


valueLength < 

value.length = 5 
valueOffset = 
valueLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Handler overflow 

value.length = 254 
valueOffset = 
valueLength = 254 


ToolkitException. HANDLER OV 
ERFLOW is thrown 




8 


Bad parameter 

value.length = 256 
valueOffset = 
valueLength = 256 


ToolkitException. BAD INPUT P 
ARAMETER is thrown 




9 


clear the handler, append the handler with 
TLVs: 

81 03 11 22 33 

82 02 99 77 








Select Command Details TLV 








Successful call 

tag = 04 

value = FF FE ... F8 
valueOffset = 
valueLength = 8 








Verify Current TLV: Call getValueLengthQ 


Result is 03h 




10 


Clear the handler 








Successful call 

tag = 04 

value = FF FE ... F8 
valueOffset = 
valueLength = 8 








Call copyO method 








Compare handler 

compareBuf fer = 04 08 FF FE ... F8 


Result Is 00 




11 


Successful call 

tag = 85h 
value = 00 01 ... 07 
valueOffset = 2 
valueLength = 6 








Call copvO method 








Compare handler 

compareBuffer = 04 08 FF FE ... F8 85 06 02 
03 ... 07 


Result is 00 




12 


Successful call 

tag = 01 

value = 11 22 ... 88 
valueOffset = 2 
valueLength = 4 








Call copyO method 








Compare handler 

compareBuffer = 04 08 FF FE ... F8 85 06 02 
03 ... 07 01 04 33 44 55 66 


Result is 00 




13 


Clear the handler 








Successful call 

tag = 04 
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value = 00 01 ... 7F 
valueOffset = 
valueLength = 80h 








Call copyO method 








Compare handler 

compareBuffer = 04 81 80 00 01. ..7F 


Result is 00 





6.2.5.18.4 



Test Coverage 



CRR number 


Test case number 


N1 


10, 11, 12, 13 


N2 


9 


P1 


1 


P2 


2,3,4,5,6 


C1 


7 


C2 


Does not apply for 

EnvelopeResponseHandl 

er 


C3 


8 



6.2.5.1 9 Method appendTLV(byte tag, byte valuel , byte[ ] value2, short value2offset, 
short value2length) 



Test Area Reference: API 2 ERH APTLBB BSS 



6.2.5.19.1 



Conformance requirement: 



The method with following header shall be compliant to its definition in the API. 

void appendTLV (byte tag, 

byte valuel 
byte [ ] value2, 
short value2of f set , 
short value21ength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
Toolkit Except ion 

Normal execution 

CRRNl: Appends a TLV element to the current TLV list (1 byte and a byte-array element). 

CRRN2: A successful append does not modify the TLV selected. 
Parameters error 

CRRPl: if value2 is null, a java.lang. NullPointerException is thrown 

CRRP2: if value2offset or value21ength or both would cause access outside the array bounds, or if length is 
negative, a Java. lang. ArraylndexOutOfBoundsException is thrown. 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 

CRRC3: if valuelength is greater than 255, a ToolkitException is thrown with reason code 
BAD_INPUT_PARAMETER 
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6.2.5.19.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.19.3 



Test suite files 

API_2_ERH_APTLVBB_BSS_1 .scr 
API_2_ERH_APTLVBB_BSS_1 .Java 
API_2_ERH_APTLVBB_BSS_1 .Idr 
API_2_ERH_APTLVBB_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Null value2 


NullPointerException is thrown 




2 


value20ffset > value2.length 

value2 . length = 5 
value20ffset = 5 
value2Length = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


value20ffset < 

value2 . length = 5 
value20ffset = -1 
value2Length = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


value2Length > value2.length 

value2 . length = 5 
value20ffset = 
value2Length = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


value20ffset + value2Length > value2.length 

value2 . length = 5 
value20ffset = 3 
value2Length = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


value2Length < 

value2 . length = 5 
value20ffset = 
value2Length = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Handler overflow 

value2 . length = 254 
value20ffset = 
value2Length = 254 


ToolkitException. HANDLER OV 
ERFLOW is thrown 




8 


Bad parameter 

value2 . length = 256 
value20ffset = 
value2Length = 256 


ToolkitException. BAD INPUT P 
ARAMETER is thrown 




9 


clear the handler, append the handler with 
TLVs: 

81 03 11 22 33 

82 02 99 77 








Select Command Details TLV 








Successful call 

tag = 04 
valuel = 05 
value2 = FF FE ... F8 
value20ffset = 
value2Length = 8 








Verify Current TLV: Call getValueLengthQ 


Result is 03h 




10 


Clear the handler 








Successful call 

tag = 04 
valuel = 05 
value2 = FF FE ... F8 
value20ffset = 
value2Length = 8 








Call copyO method 








Compare handler 

CompareBuffer = 04 09 05 FF FE ... F8 


Result is 00 




11 


Successful call 

tag = 85h 
valuel = 55h 
value2 = 00 01 ... 07 
value20ffset = 2 
value2Length = 6 








Call copvO method 








Compare handler 


Result is 00 
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CompareBuf fer = 

04 09 05 FF FE ... F8 

85 07 55 02 03 ... 07 






12 


Successful call 

tag = 01 
valuel = 44h 
value2 = 11 22 ... 88 
value20ffset = 2 
value2Length = 4 








Call copyO method 








Compare handler 

CompareBuf fer = 
04 09 05 FF FE ... F8 
85 07 55 02 03 ... 07 
01 05 44 33 44 55 66 


Result is 00 




13 


Clear the handler 








Successful call 

tag = 04 
valuel = 00 
value2 = 01 ... 7F 
value20ffset = 
value2Length = 7Fh 








Call copyO method 








Compare handler 

CompareBuf fer = 04 81 80 00 01. ..7F 


Result is 00 





6.2.5.19.4 



Test Coverage 



CRR number 


Test case number 


N1 


10, 11, 12, 13 


N2 


9 


PI 


1 


P2 


2, 3, 4, 5, 6 


CI 


7 


C2 


Does not apply for 

EnvelopeResponseHandl 

er 


C3 


8 



6.2.5.20 Method clear 

Test Area Reference: API_2_ERH_CLER 

6.2.5.20.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

void clear ( ) 

throws ToolkitException 

Normal execution 

CRRNl: Clears the TLV list of an EditHandler and resets the current TLV selected. 
Parameters error 

No requirements 

Context errors 

CRRCl: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 

6.2.5.20.2 Test suite files 

Test Script: API_2_ERH_CLER_l.scr 
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Test Applet: 
Load Script: 
Clean-up Script: 

6.2.5.20.3 



API_2_ERH_CLER_1 .Java 
API_2_ERH_CLER_1 .Idr 
API 2 ERH CLER Lck 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


append the handler with TLVs: 

81 03 11 22 33 

82 02 99 77 

Select Command Details TLV 
Call the getLengthO method 


Result of getLengthO is not null 






Clear the handler 

Call the getLengthO method 


Result of getLengthO is 




2 


Call the getValueLengthO method 


Tooll<itException.UNAVAILABLE 
ELEIVIENT is thrown 





6.2.5.20.4 



Test Coverage 



CRR number 


Test case number 


N1 


1, 2 


C1 


Does not apply for 

EnvelopeResponseHandl 

er 



6.2.6 Class MEProfile 
6.2.6.1 Method check (byte index) 

Test Area Reference: API_2_MEP_CHECB 

6.2.6.1.1 Conformance requirement: 

The method with following header shall compliant to its definition in the API. 

public static boolean check (byte index) 
throws ToolkitException 

Normal execution 

CRRNl: The method checks a facility in the handset profile: returns true if supported and false if not. 

Parameters error 

CRRPl: The method shall throw ME_PROFILE_NOT_AVAILABLE ToolkitException if Terminal Profile data are 
not available 

Context errors 
None 

6.2.6.1.2 Test suite files 
Specific triggering: 

UNFORMATTED_SMS_PP_UPD 
No Additional requirements for the GSM personalisation: 

Test Script: API_2_MEP_CHECB_l.scr 
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Test Applet: 



API_2_MEP_CHECB_1 Java 



Installation parameter: Terminal Profile = Ox (FF 7F FF FF FF FF FF FF FF FF FF FF FF FF FF FF) (facility index 
15 not supported) 



Load Script: 
Cleaning Script: 

6.2.6.1.3 



API_2_MEP_CHECB_1 .Idr (the applet is loaded without INI after the reset (RST) 
API 2 MEP CHECB l.ck 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


No Terminal Profile is registered 

Triggered by unformatted SMS 
Index = 1 


ME_PROFILE_NOT_AVAILABLE 
ToolkitException is thrown 




2 


Terminal Profile, Facility is supported 

index = 


true is returned by the method 




3 


Terminal Profile, Facility is not supported 

Index = 15 


false is returned by the method 





6.2.6.1.4 



Test Coverage 



CRR number 


Test case number 


N1 


2,3 


P1 


1 



6.2.6.2 Method check (byte [ ] mask, short offset, short length) 

Test Area Reference: API_2_MEP_CHEC_BSS 



6.2.6.2.1 



Conformance requirement: 



The method with following header shall compliant to its definition in the API. 

public static boolean check (byte [ ] mask, 

short offset, 
short length) 
throws Java . lang . NullPointerException, 

Java , lang, ArraylndexOutOf BoundsException, 
ToolkitException 

Normal execution 

CRRNl: The method checks all the facilities corresponding to bits set to 1 in the mask buffer: returns true if they 
are all supported and false if not. 

CRRN2: The method returns true if the length to check is 0. 

Parameters error 

CRRPl: The method shall throw Java. lang. NullPointerException if mask is null. 

CRRP2: The method shall throw java.lang.ArraylndexOutOfBoundsException if offset or length or both would 
cause access outside array bounds. 

CRRP3: The method shall throw ME_PROFILE_NOT_A VAIL ABLE ToolkitException if Terminal Profile data are 
not available. 

Context errors 
None 

6.2.6.2.2 Test suite files 

Specific triggering: 
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UNFORMATTED_SMS_PP_UPD 

No Additional requirements for the GSM personalisation: 

Test Script: API_2_MEP_CHEC_BSS_l.scr 

Test Applet: API_2_MEP_CHEC_BSS_l.java 

Installation parameter: Terminal Profile = Ox(FF 7F FF FF FF FF FF FF FF FF FF FF FF FF FF FF) (facility 
index 15 not supported) 



Load Script: 
Cleaning Script: 

6.2.6.2.3 



API_2_MEP_CHEC_BSS_l.ldr (the applet is loaded without INI after the reset (RST)) 
API_2_MEP_CHEC_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU 
Expectation 


1 


No Terminal Profile is registered 

Triggered by unformatted SMS 

Mask = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7F 

Offset = 

Length = 16 


ME_PROFILE_NOT_AVAIL 
ABLE ToolkitException is 
thrown 




2 


NULL as parameter to check 

mask= NULL 


NullPointerException is 
thrown 




3 


Offset > mask.length 

mask = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7F 
Offset = 17 


ArraylndexOutOfBoundsExc 
eption is thrown 




4 


Offset < 

mask = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7F 
Offset = -1 


ArraylndexOutOfBoundsExc 
eption is thrown 




5 


Length > mask.length 

mask = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7F 
Offset = 
Length =18 


ArraylndexOutOfBoundsExc 
eption is thrown 




6 


Offset + length > mask.length 

Mask = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7F 
Offset = 9 
Length = 9 


ArraylndexOutOfBoundsExc 
eption is thrown 




7 


length = 

mask = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7F 
Offset = 
Length = 


true is returned 




8 


Check all the Terminal Profile 

mask = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7F 
Offset = 
Length = 16 


false is returned by the 
method because facility 15 is 
not supported 




9 


Check a part of the Terminal Profile 

mask = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF7F 
Offset = 15 
Length = 2 


true is returned by the 
method: the 16 first facilities 
except facility 15 have been 
successfully checked 




10 


Check a part of the Terminal Profile 

mask = 0x0080 
Offset = 
Length = 2 


false is returned by the 
method only facility 15 is 
checked and not supported. 





6.2.6.2.4 



Test Coverage 



CRR number 


Test case number 


N1 


8,9,10 


N2 


7 


PI 


2 


P2 


3,4,5,6 


P3 


1 
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6.2.7 Class ProactiveHandler 
6.2.7.1 Method getTheHandler 

Test Area Reference: API_2_PAH_GTHD 

6.2.7.1.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public static ProactiveHandler getTheHandler ( ) 

throws ToolkitException 

Normal execution 

CRRNl: The method shall return the single system instance of the ProactiveHandler class. 
CRRN2: The EnvelopeHandler is a Temporary JCRE Entry Point Object 

Parameter errors 

Context errors 

CRRCl: The method shall throw ToolkitException.HANDLER_NOT_AVAILABLE if the handler is busy. 



6.2.7.1.3 

Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.1.3 



Test Suite files 

API_2_PAH_GTHD_1 . scr 
API_2_PAH_GTHD_1 .j ava 
API_2_PAH_GTHD_1 .Idr 
API_2_PAH_GTHD_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


getTheHandlerQ twice 


The returned objects shall be the 
same 




2 


getTheHandlerO 


The reference shall be a 
ProactiveHandler 




3 


getTheHandlerO 


The reference shall not be null 





6.2.7.1.4 



Test Coverage 



CRR number 


Test case number 


N1 


1, 2, 3 


N2 


To be checked in 

Framework tests and 

insert here cross 

reference 


C1 


To be checked in 

Framework tests and 

insert here cross 

reference 



6.2.7.2 Method init 

Test Area Reference: API_2_PAH_INITBBB 
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6.2.7.2.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public void init (byte type, 

byte qualifier, 
byte dstDevice) 

Normal execution 

CRRNl: The init() method initialises the next Proactive command in the ProactiveHandler, with Command details 
and Device Identities TLV. The source device is always the SIM Card (81h). The Comprehension Required flags 
are set. 

CRRN2: The Command number may take any value between Olh and FEh. 

CRRN3: The init() method clears the ProactiveHandler before initialising it. 

CRRN4: No TLV is selected after a call to the method. 

CRRN5: The handler is not sent to the mobile by the init() method. 

Parameter errors 

Context errors 

6.2.7.2.3 Test Suite files 

Test Script: API_2_PAH_INITBBB_l.scr 

Test Applet: API_2_PAH_INITBBB_l.java 

Load Script: API_2_PAH_INITBBB_l.ldr 

Clean-up Script: API_2_PAH_INITBBB_1 .clr 
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6.2.7.2.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Call the initO method 

type = Olh 
qualifier = 02h 
dstDevice = 03h 

Copy ProactiveHandler in a byte array 

(source) 

Compare the byte array 

reference = 

81h 03h xxh Olh 02h 

82h 02h 81h 03h 


source and reference are 
identical 




2 


Verify the command number value 


01h-FEh 




3 


Call the initO method 

type = FFh 
qualifier = FEh 
destination = FDh 

Copy ProactiveHandler in a byte array 

(source) 

Compare the byte array 

reference = 

81h 03h xxh FFh FEh 

82h 02h 81h FDh 


source and reference are 
identical 




4 


Select the 1st TLV in the handler 
Call the init() method with any value 








Call the getValueLengthQ method 


UNAVAILABLE_ELEMENT 
ToolkitException is thrown by 
getValueLengthO 





6.2.7.2.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,3 


N2 


2 


N3 


3 


N4 


4 


N5 


1,3 



6.2.7.3 Method initDisplayText 

Test Area Reference: API_2_PAH_INDTBB_BSS 

6.2.7.3.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public void initDisplayText (byte qualifier, 

byte dcs, 
byte [ ] buffer, 
short offset, 
short length) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: The method shall build a DISPLAY TEXT proactive command in the ProactiveHandler, using qualifier, 
dcs and buffer parameters. Comprehension required flags are set. 

CRRN2: A call to this method clears the handler then initialises it. 

CRRN3: No TLV is selected after a call to the method. 
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CRRN4: The DISPLAY TEXT command is not sent by the method. 
CRRN5: The Command Number may take any value between Olh and FEh. 

Parameter errors 

CRRPl: The method shall throw NullPointerException if buffer is null. 

CRRP2: If offset or length or both would cause access outside array bounds, an ArraylndexOutOfBoundsException 
shall be thrown. 

Context errors 

CRRCl: A ToolkitException.HANDLER_OVERFLOW shall be thrown if the ProactiveHandler is too small to put 
the requested data. 



6.2.7.3.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.3.3 



Test Suite files 

API_2_PAH_INDTBB_BSS_Lscr 
API_2_PAH_INDTBB_BSS_1 .Java 
API_2_PAH_INDTBB_BSS_1 .Mr 
API_2_PAH_INDTBB_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


NULL as parameter to buffer 

buffer = NULL 


NullPointerException is thrown 




2 


offset > buffer.length 

buffer = "Text" 
offset = 5 
length = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


Offset < 

buffer = "Text" 
offset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > buffer.length 

buffer = "Text" 
offset = 
length = 5 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


offset + length > buffer.length 

buffer = "Text" 
offset = 3 
length = 2 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


length < 

buffer = "Text" 
offset = 3 
length = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Successful call, buffer is the whole buffer 

qualifier = 
dcs = 4 

buffer = "TextA" 
offset = 
length = 5 


No exception is thrown 






Verify the command number value 


Command number between 01 h 
and FEh 




8 


Send the command 




DISPLAY TEXT Proactive 
command 

qualifier = OOh 

dcs = 4 

Text = "TextA" 


9 


Succesfull call, buffer is part of a buffer with 

the end part 

Send the command 

qualifier = 
dcs = 4 




DISPLAY TEXT Proactive 
command 

qualifier = OOh 
dcs = 4 
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buffer = "12TextB" 
offset = 2 
length = 5 




Text = "TextB" 


10 


Succesfull call, buffer is part of a buffer with 

the first part 

Send the command 

qualifier = 
dcs = 4 

buffer = "TextC12" 
offset = 
length = 5 




DISPLAY TEXT Proactive 
command 

qualifier = OOh 

dcs = 4 

Text = "TextC" 


11 


Succesfull call, buffer is part of a buffer 
Send the command 

qualifier = 

dcs = 4 

buffer = "12TextD34" 

offset = 2 

length = 5 




DISPLAY TEXT Proactive 
command 

qualifier = OOh 

dcs = 4 

Text = "TextD" 


12 


Succesfull call, qualifier = 81h 
Send the command 

qualifier = 81h 
dcs = 4 

buffer = "TextE" 
offset = 
length = 5 




DISPLAY TEXT Proactive 
command 

qualifier = 81h 

dcs = 4 

Text = "TextE" 


13 


Succesfull call, DCS=0 (7 bits) 
Send the command 

qualifier = 
dcs = 

buffer = "TextF" 
offset = 
length = 5 




DISPLAY TEXT Proactive 
command 

qualifier = OOh 

dcs = 

Text = "TextF" 


14 


Succesfull call, DCS=8 (UCS2) 
Send the command 

qualifier = 
dcs = 8 

buffer = "TextG" 
offset = 
length = 5 




DISPLAY TEXT Proactive 
command 

qualifier = OOh 

dcs = 8 

Text = "TextG" 


15 


Call the InitDlsplayTextO method with any 

value 

Then build and send a DISPLAY TEXT 

command 

qualifier = 

dcs = 4 

buffer = "TextHTextH" 

offset = 

length = 10 




DISPLAY TEXT Proactive 
command 

qualifier = OOh 

dcs = 4 

Text = "TextHTextH" 


16 


Successful call, text length is null 
Send the command 

qualifier = 

dcs = 4 

buffer = "" (not null buffer) 

offset = 

length = 




DISPLAY TEXT Proactive 
command 

qualifier = OOh 

Text String TLV = 8D 00 


17 


Select a TLV in the ProactiveHandler 
Call the initDisplayTextQ method 
Call the getValueLengthO method 


UNAVAILABLE_ELEMENT 
ToolkitException is thrown by 
getValueLengthO 




18 


Successful call, buffer length = 7Eh 

qualifier = 
dcs = 4 

buffer = "UUU..." 
offset = 
length = 7Eh 




DISPLAY TEXT Proactive 
command 

Text String TLV = 
8D 7F 04 55 55... 


19 


Successful call, buffer length = 7Fh 

qualifier = 
dcs = 4 

buffer = "UUU..." 
offset = 
length = 7Fh 




DISPLAY TEXT Proactive 
command 

Text String TLV = 8D 81 
80 04 55 55... 


20 


Successful call, buffer length = 240 




DISPLAY TEXT Proactive 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



135 



ETSI TS 101 955 V7.1.0 (2001-06) 





Qualifier = 
dcs = 4 

buffer = "UUU..." 
offset = 
length = 240 




command 

Text String TLV = 
8D 81 Fl 04 55 55... 


21 


Call the inltDlsplayTextO method with a too 
long buffer 

qualifier = 
dcs = 4 

buffer = "XXXX..." 
offset = 
length = 241 


HANDLER_OVERFLOW 
ToolkitException is thrown 




22 


Call the InltDlsplayTextO without sending the 
command 




No proactive command 
sliall be sent expected 
status is '9000' 



6.2.7.3.4 



Test Coverage 



CRR number 


Test case number 


N1 


8,9, 10, 11, 12, 13, 14, 
15, 16, 18, 19,20 


N2 


15 


N3 


17 


N4 


22 


N5 


7 


P1 


1 


P2 


2, 3, 4, 5, 6 


C1 


21 



6.2.7.4 Method initGetlnkey 

Test Area Reference: API_2_PAH_INGKBB_BSS 



6.2.7.4.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public void initGetlnkey (byte qualifier^ 

byte dcs, 
byte [ 1 buffer, 
short offset, 
short length) 
throws Java . lang . NullPointerException, 

Java .lang . Array IndexOutOfBoundsExcept ion, 
ToolkitException 



Normal execution 



CRRNl: The method shall build a GET INKEY proactive command in the ProactiveHandler, using qualifier, dcs 
and buffer parameters. Comprehension Required flags are set. 

CRRN2: A call to this method clears the handler then initialises it. 

CRRN3: No TLV is selected after a call to the method. 

CRRN4: The GET INKEY command is not sent by the method. 

CRRN5: The Command Number may take any value between Olh and FEh. 

Parameter errors 

CRRPl: The method shall throw NullPointerException if buffer is null. 

CRRP 1 : If offset or length or both would cause access outside array bounds, a ArraylndexOutOfBoundsException 
shall be thrown. 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



136 



ETSI TS 101 955 V7.1.0 (2001-06) 



Context errors 

CRRCl: A ToolkitException.HANDLER_OVERFLOW shall be thrown if the ProactiveHandler is to small to put 
the requested data. 



6.2.7.4.3 

Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.4.3 



Test Suite files 

API_2_PAH_INGKBB_BSS_1 .scr 
API_2_PAH_INGKBB_BSS_1 Java 
API_2_PAH_INGKBB_BSS_1 .Idr 
API_2_PAH_INGKBB_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


NULL as parameter to buffer 

buffer = NULL 


NullPointerException is thrown 




2 


Offset > buffer.length 

buffer = "Text" 
offset = 5 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


Offset < 

buffer = "Text" 
offset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > buffer.length 

buffer = "Text" 
offset = 
length = 5 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


Offset + length > buffer.length 

buffer = "Text" 
offset = 3 
length = 2 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


length < 

buffer = "Text" 
offset = 3 
length = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Successful call, buffer is the whole buffer 

qualifier = 
dcs = 4 

buffer = "TextA" 
offset = 
length = 5 


No exception is thrown 






Verify the command number value 


Command number between 01 h 
and FEh 




8 


Send the command 




GET INKEY Proactive 
command 

qualifier = OOh 

dcs = 4 

Text = "TextA" 


9 


Succesfull call, buffer is part of a buffer with 
the end part 

qualifier = 
dcs = 4 

buffer = "12TextB" 
offset = 2 
length = 5 




GET INKEY Proactive 
command 

qualifier = OOh 

dcs = 4 

Text = "TextB" 


10 


Succesfull call, buffer is part of a buffer with 
the first part 

qualifier = 
dcs = 4 

buffer = "TextC12" 
offset = 
length = 5 




GET INKEY Proactive 
command 

qualifier = OOh 

dcs = 4 

Text = "TextC" 


11 


Succesfull call, buffer is part of a buffer 
Send the command 

qualifier = 

dcs = 4 

buffer = "12TextD34" 




GET INKEY Proactive 
command 

qualifier = OOh 
dcs = 4 
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offset = 2 
length = 5 




Text = "TextD" 


12 


Succesfull call, qualifier = 81h 

qualifier = 81h 
dcs = 4 




GET INKEY Proactive 
command 




buffer = "TextE" 
offset = 
length = 5 




qualifier = 81h 

dcs = 4 

Text = "TextE" 


13 


Succesfull call, DCS=0 (7 bits) 

qualifier = 
dcs = 




GET INKEY Proactive 
command 




buffer = "TextF" 
offset = 
length = 5 




qualifier = OOh 

dcs = 

Text = "TextF" 


14 


Succesfull call, DCS=8 (UCS2) 

qualifier = 
dcs = 8 




GET INKEY Proactive 
command 




buffer = "TextG" 
offset = 
length = 5 




qualifier = OOh 

dcs = 8 

Text = "TextG" 


15 


Call the initGetlnkeyO method with any value 
Then build and send a GET INKEY command 




GET INKEY Proactive 
command 




qualifier = 

dcs = 4 

buffer = "TextHTextH" 

offset = 

length = 10 




qualifier = OOh 

dcs = 4 

Text = "TextHTextH" 


16 


Successful call, text length is null 
Send the command 




GET INKEY Proactive 
command 




qualifier = 
dcs = 4 
buffer = "" 
offset = 
length = 




qualifier = OOh 

Text String TLV = 8D 00 


17 


Select a TLV in the ProactiveHandler 

Call the initGetlnkeyO method 

Call the getValueLengthO method 


UNAVAILABLE_ELEMENT 
ToolkitException is thrown by 
getValueLengthO 




18 


Successful call, buffer length = 7Eh 

qualifier = 




GET INKEY Proactive 
command 




dcs = 4 

buffer = "UUU..." 
offset = 
length = 7Eh 




Text String TLV = 
8D 7F 04 55 55... 


19 


Successful call, buffer length = 7Fh 

qualifier = 




GET INKEY Proactive 
command 




dcs = 4 

buffer = "UUU..." 
offset = 
length = 7Fh 




Text String TLV = 8D 81 
80 04 55 55... 


20 


Successful call, buffer length = 240 

Qualifier = 




GET INKEY Proactive 
command 




dcs = 4 

buffer = "UUU..." 
offset = 
length = 240 




Text String TLV = 
8D 81 Fl 04 55 55... 


21 


Call the initGetlnkeyO method with a too long 
buffer 

qualifier = 
dcs = 4 

buffer = "XXXX..." 
offset = 
length = 241 


HANDLER_OVERFLOW 
ToolkitException is thrown 




22 


Call the InitGetlnkeyO without sending the 
command 




No proactive command 
shall be sent expected 
status is '9000' 
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6.2.7.4.4 



Test Coverage 



CRR number 


Test case number 


N1 


8,9, 10, 11, 12, 13, 14, 
15, 16, 18, 19,20 


N2 


15 


N3 


17 


N4 


22 


N5 


7 


P1 


1 


P2 


2, 3, 4, 5, 6 


C1 


21 



6.2.7.5 Method initGetlnput 

Test Area Reference: API 2 PAH INGPBB BSSSS 



6.2.7.5.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public void initGetlnput (byte qualifier, 

byte dcs, 
byte [ ] buffer, 
short offset, 
short length, 
short minRespLength, 
short maxRespLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: The method shall build a GET INPUT proactive command in the ProactiveHandler, using qualifier, dcs, 
buffer, minRespLength and maxRespLength parameters. Comprehension Required flags are set. 

CRRN2: A call to this method clears the handler then initialises it. 

CRRN3: No TLV is selected after a call to the method. 

CRRN4: The GET INPUT command is not sent by the method. 

CRRN5: The Command Number may take any value between Olh and FEh. 

Parameter errors 

CRRPl: The method shall throw NullPointerException if buffer is null. 

CRRP2: If offset or length or both would cause access outside array bounds, a ArraylndexOutOfBoundsException 
shall be thrown. 

Context errors 

CRRCl: A ToolkitException.HANDLER_OVERFLOW shall be thrown if the ProactiveHandler is to small to put 
the requested data. 

6.2.7.5.3 Test Suite files 

Test Script: API_2_PAH_INGPBB_BSSSS_l.scr 

Test Applet: API_2_PAH_INGPBB_BSSSS_l.java 

Load Script: API_2_PAH_INGPBB_BSSSS_l.ldr 
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Clean-up Script: 



API_2_PAH_INGPBB_BSSSS_1 .clr 



6.2.7.5.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


NULL as parameter to buffer 

buffer = NULL 


NullPointerException is thrown 




2 


offset > buffer.length 


ArraylndexOutOfBoundsExceptio 






buffer = "Text" 


n is tlirown 






offset = 5 






3 


Offset < 


ArraylndexOutOfBoundsExceptio 






buffer = "Text" 


n is tlirown 






offset = -1 






4 


length > buffer.length 


ArraylndexOutOfBoundsExceptio 






buffer = "Text" 


n is thrown 






offset = 








length = 5 






5 


offset + length > buffer.length 


ArraylndexOutOfBoundsExceptio 






buffer = "Text" 


n is thrown 






offset = 3 








length = 2 






6 


length < 


ArraylndexOutOfBoundsExceptio 






buffer = "Text" 


n is thrown 






offset = 3 








length = -1 






7 


Successful call, buffer is the whole buffer 

qualifier = 

dcs = 4 

buffer = "TextA" 

offset = 

length = 5 

minRespLength = OOh 

maxRespLength = FFh 


No exception is thrown 






Verify the command number value 


Command number between 01 h 
and -FEh 




8 


Send the command 




GET INPUT Proactive 
command 

qualifier = OOh 
dcs = 4 

Text = "TextA" 
Min Length = OOh 
Max Length = FFh 


9 


Succesfull call, buffer is part of a buffer with 




GET INPUT Proactive 




the end part 




command 




Send the command 








qualifier = 




qualifier = OOh 




dcs = 4 




dcs = 4 




buffer = "12TextB" 




Text = "TextB" 




offset = 2 




Min Length = lOh 




length = 5 




Max Length = FFh 




minRespLength = lOh 








maxRespLength = FFh 






10 


Succesfull call, buffer is part of a buffer with 




GET INPUT Proactive 




the first part 




command 




Send the command 








qualifier = 




qualifier = OOh 




dcs = 4 




dcs = 4 




buffer = "TextC12" 




Text = "TextC" 




offset = 




Min Length = FFh 




length = 5 




Max Length = FFh 




minRespLength = FFh 








maxRespLength = FFh 






11 


Succesfull call, buffer is part of a buffer 




GET INPUT Proactive 




Send the command 




command 




qualifier = 








dcs = 4 




qualifier = OOh 




buffer = "12TextD34" 




dcs = 4 




offset = 2 




Text = "TextD" 




length = 5 




Min Length = OOh 




minRespLength = OOh 




Max Length = OOh 




maxRespLength = OOh 
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12 


Succesfull call, qualifier = 81h 




GET INPUT Proactive 




qualifier = 81h 




command 




dcs = 4 








buffer = "TextE" 




qualifier = 81h 




offset = 




dcs = 4 




length = 5 




Text = "TextE" 




minRespLength = OOh 




Min Length = OOh 




maxRespLength = lOh 




Max Length = lOh 


13 


Succesfull call, DCS=0 (7 bits) 




GET INPUT Proactive 




qualifier = 




command 




dcs = 








buffer = "TextF" 




qualifier = OOh 




offset = 




dcs = 




length = 5 




Text = "TextF" 




minRespLength = lOh 




Min Length = lOh 




maxRespLength = lOh 




Max Length = lOh 


14 


Succesfull call, DCS=8 (UCS2) 




GET INPUT Proactive 




qualifier = 




command 




dcs = 8 








buffer = "TextG" 




qualifier = OOh 




offset = 




dcs = 8 




length = 5 




Text = "TextG" 




minRespLength = OOh 




Min Length = OOh 




maxRespLength = FFh 




Max Length = FFh 


15 


Call the initGetlnputO method with any value 




GET INPUT Proactive 




Then build and send a GET INPUT command 




command 




qualifier = 








dcs = 4 




qualifier = OOh 




buffer = "TextHTextH" 




dcs = 4 




offset = 




Text = "TextHTextH" 




length = 10 




Min Length = OOh 




minRespLength = OOh 




Max Length = lOh 




maxRespLength = lOh 






16 


Successful call, text length is null 




GET INPUT Proactive 




Send the command 




command 




qualifier = 








dcs = 4 




qualifier = OOh 




buffer = "" 




Text String TLV = 8D 00 




offset = 




Min Length = OOh 




length = 




Max Length = lOh 




minRespLength = OOh 








maxRespLength = lOh 






17 


Select a TLV in the ProactiveHandler 


UNAVAILABLE_ELEMENT 






Call the initGetlnputO method 


ToolkitException is thrown by 






Call the getValueLengthO method 


getValueLengthO 




18 


Successful call, buffer length = 7Eh 

qualifier = 




GET INPUT Proactive 
command 




dcs = 4 




Text String TLV = 




buffer = "UUU..." 




8D 7F 04 55 55... 




offset = 




Min Length = OOh 




length = 7Eh 




Max Length = lOh 




minRespLength = OOh 








maxRespLength = lOh 






19 


Successful call, buffer length = 7Fh 

qualifier = 




GET INPUT Proactive 
command 




dcs = 4 




Text String TLV = 8D 81 




buffer = "UUU..." 




80 04 55 55... 




offset = 




Min Length = OOh 




length = 7Fh 




Max Length = lOh 




minRespLength = OOh 








maxRespLength = lOh 






20 


Successful call, buffer length = 236 

Qualifier = 




GET INPUT Proactive 
command 




dcs = 4 




Text String TLV = 




buffer = "UUU..." 




8D 81 ED 04 55 55... 




offset = 








length = 236 








minRespLength = OOh 
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maxRespLength = lOh 






21 


Call the InitGetlnputO method with a too long 
buffer 

qualifier = 

dcs = 4 

buffer = "XXXX..." 

offset = 

length = 237 

minRespLength = OOh 

maxRespLength = lOh 


HANDLER_OVERFLOW 
ToolkitException Is thrown 




22 


Call the InitGetlnputO without sending the 
command 




No proactive command 
shall be sent expected 
status is '9000' 



6.2.7.5.4 



Test Coverage 



CRR number 


Test case number 


N1 


8,9, 10, 11, 12, 13, 14, 
15, 16, 18, 19,20 


N2 


15 


N3 


17 


N4 


22 


N5 


7 


P1 


1 


P2 


2, 3, 4, 5, 6 


C1 


21 



6.2.7.6 Method send 

Test Area Reference: API_2_PAH_SEND 

6.2.7.6.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte send() 

Normal execution 

CRRNl: The send() method send the current proactive command to the mobile. 

CRRN2: The returned byte is equal to general result of the command (first byte of Result TLV in Terminal 
Response). 

CRRN3: The handler remains unchanged after a call to send() method until the use of initXX() or appendTLV(). 

CRRN4: There is no invocation of select() or deselect() method. 

CRRN5: A pending toolkit applet transaction at the method invocation is aborted. 

Parameter errors 

Context errors 

CRRCl: A ToolkitException. UNAVAILABLE_ELEMENT shall be thrown is the Result Simple TLV is missing in 
Terminal Response. 

CRRC2: A ToolkitException.OUT_OF_TLV_BOUND ARIES shall be thrown if the general result byte is missing 
in the Result Simple TLV in Terminal Response. 

6.2.7.6.3 Test Suite files 

Test Script: API_2_PAH_SEND_Lscr 

Test Applet: API_2_PAH_SEND_Ljava 
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Load Script: 
Clean-up Script: 

6.2.7.6.3 



API_2_PAH_SEND_1 
API_2_PAH_SEND_1 



Idr 
clr 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a DISPLAY TEXT command 

qualifier = OOh 
dcs = 04h 
buffer = 'Text' 




DISPLAY TEXT Proactive 
command 


2 


Terminal Response with General Result = 00 

Result TLV = 03 01 00 (command performed 
successfully) 


Result of sendQ is OOh 




3 


Build and send a DISPLAY TEXT command 

qualifier = OOh 
dcs = 04h 
buffer = 'Text' 




DISPLAY TEXT Proactive 
command 


4 


Terminal Response with General Result = 01 , 
without Additional information on result 

Result TLV = 03 01 01 (command performed 
with partial comprehension) 


Result of sendQ is 01 h 




5 


Build and send a DISPLAY TEXT command 

qualifier = OOh 
dcs = 04h 
buffer = 'Text' 




DISPLAY TEXT Proactive 
command 


6 


Terminal Response with General Result = 01 , 
with Additional information on result 

Result TLV = 03 02 01 55 (command 
performed with partial comprehension) 


Result of sendQ is 01 h 




7 


Build and send a DISPLAY TEXT command 

qualifier = OOh 
dcs = 04h 
buffer = 'Text' 




DISPLAY TEXT Proactive 
command 


8 


Terminal Response with General Result = 02 

Result TLV = 03 04 02 65 43 21 (Missing 
information) 


Result of sendQ is 02h 




9 


Build and send a 7Fh byte command 
(DISPLAY TEXT) 

qualifier = OOh 
dcs = 04h 
buffer = "UUUUU..." 
length = 73h 




DISPLAY TEXT Proactive 
command 

BER-TLV = DO 7F 

Text String TLV = 8D 74 

04 55 55 55... 


10 


Build and send a 80h byte command 
(DISPLAY TEXT) 

qualifier = OOh 
dcs = 04h 
buffer = "UUUUU..." 
length = 74h 




DISPLAY TEXT Proactive 
command 

BER-TLV = DO 81 80 
Text String TLV = 8D 75 

04 55 55 55... 


11 


Build and send a maximum length command 
(length of the handler should be 253) 

DISPLAY TEXT: 
Qualifier = 
dcs = 4 

buffer = "UUU..." 
offset = 
length = 240 




DISPLAY TEXT Proactive 
command 

BER-TLV = DO 81 FD 
Text String TLV = 8D 81 
Fl 04 55 55... 


12 


Verify that the Proactive Handler is not 

modified after a send() 

Build a DISPLAY TEXT command 

Copy ProactiveHandler to source byte array 

Send command 

Copy ProactiveHandler to destination byte 
array 
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Compare source and destination 


Source and destination are 
identical 




13 


Build and send a DISPLAY TEXT command 

Verify there is no Invocation of select() or 

deselectO method. 




DISPLAY TEXT Proactive 
command 


14 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 2 Result TLV 

1st Result TLV = 03 02 02 12 
2nd Result TLV = 03 03 03 34 56 


Result of sendQ is 02h 




15 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response without Result Simple 
TLV 


ToolkitException.UNAVAILABLE 
_ELEMENT is thrown by sendQ 




16 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response without general result 
byte in the Simple TLV 

Result TLV = 03 00 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown by 
sendQ 





6.2.7.6.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,3,5,7,9, 10, 11, 12, 
13, 14 


N2 


2,4,6,8, 14 


N3 


12 


N4 


13 


N5 


To be checl<ed in 

Frameworl< tests and 

insert here cross 

reference 


CI 


15 


C2 


16 



6.2.7.7 Method getLength 

Test Area Reference API_2_PAH_GLEN 

6.2.7.7.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getLength () 

throws ToolkitException 

Normal execution 

CRRNl: returns the length in bytes of the TLV list. 

Parameter errors 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AV AIL ABLE. 
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6.2.7.7.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.7.3 



Test Suite files 

API_2_PAH_GLEN_1 .scr 
API_2_PAH_GLEN_1 .Java 
API_2_PAH_GLEN_1 .Idr 
API_2_PAH_GLEN_1 xlr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Clear the handler 

getLength () 


Result of getLengthO is 




2 


Call the initO method 

getLength () 


Result of getLengthO is 9 




3 


Call the InitDisplayTextO method, with buffer 
length = 240 

getLength () 


Result of getLengthO is 253 




4 


Build a 7Fh Proactive Handler 

getLength () 


Result of getLengthO is 7Fh 




5 


Build a 80h Proactive Handler 

getLength {) 


Result of getLengthO is 80h 





6.2.7.7.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3,4,5 


C1 


Does not apply for 
Proactive Handler 



6.2.7.8 Method copy 

Test Area Reference API_2_PAH_COPY_BSS 

6.2.7.8.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short copy (byte [] dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
Toolkit Except ion 

Normal execution 

CRRNl: copies the simple TLV list contained in the handler to the destination byte array. 
CRRN2: returns dstOffset + dstLength. 

Parameter errors 

CRRPl: if dstBuffer is null a NullPointerException is thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative, an 
ArraylndexOutOfBoundsException is thrown. 
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CRRP3: if dstLength is grater than the length of the simple TLV List, an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException. OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 



6.2.7.8.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.8.3 



Test Suite files 

API_2_PAH_C0PY_BSS_Lscr 
API_2_PAH_ COPY_BSS_Ljava 
API_2_PAH_ COPY_BSS_l.ldr 
API_2_PAH_ COPY_BSS_Lclr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


NULL as parameter to dstBuffer 


NullPointerException is thrown 




2 


Call the initQ method 








dstOffset > dstBuffer.length 

dstBuffer .length = 5 
dstOffset = 6 
dstLength = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


dstLength > dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength > dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


dstLength > length of the simple TLV list 

dstBuffer.length = 10 
dstOffset = 
dstLength = 10 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


Successful call, dstBuffer is the whole buffer 

dstBuffer.length = 9 
dstOffset = 
dstLength = 9 


Result of copyQ is 9 




9 


Compare the buffer 


Result of arrayCompareO is 




10 


Successful call, dstBuffer is part of a buffer 

dstBuffer.length = 15 
dstOffset = 3 
dstLength = 9 


Result of copyQ is 12 




11 


Compare the whole buffer 


Result of arrayCompareO is 




12 


Successful call, dstBuffer is part of a buffer 

dstBuffer.length = 15 
dstOffset = 3 
dstLength = 6 


Result of copyO is 9 




13 


Compare the whole buffer 


Result of arrayCompareO is 
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6.2.7.8.4 



Test Coverage 



CRR number 


Test case number 


N1 


9, 11, 13 


N2 


8, 10, 12 


P1 


1 


P2 


2,3,4,5,6 


P3 


7 


C1 


Does not apply for 
ProactiveHandler 



6.2.7.9 Method findTLV 

Test Area Reference API_2_PAH_FINDBB 

6.2.7.9.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte findTLV (byte tag, byte occurrence) 
throws ToolkitException 

Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of the TLV list (handler buffer): 

CRRNl: the method is successful if the required occurrence exists then the corresponding TLV becomes current. 

CRRN2: if the method is successful then it returns TLV_FOUND_CR_SET when Comprehension Required flag is 
set. 

CRRN3: if the method is successful then it returns TLV_FOUND_CR_NOT_SET when Comprehension Required 
flag is not set. 

CRRN4: if the required occurrence of the TLV element does not exist, the current TLV is no longer defined and 
TLV_NOT_FOUND is returned. 

CRRN5: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if an input parameter is not valid (e.g. occurrence = 0) an instance of ToolkitException shall be thrown. 
The reason code shall be ToolkitException BAD_INPUT_PARAMETER. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 



6.2.7.9.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_PAH_FINDBB_l.scr 
API_2_PAH_FINDBB_1 .Java 
API_2_PAH_FINDBB_1 .Idr 
API_2_PAH_FINDBB_1 .clr 
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6.2.7.9.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








Invalid input parameter 

Occurrence = 


ToolkitException.BAD INPUT P 
ARAMETER is thrown 




2 


Call the initO method 








Search 1st TLV 

Tag = Olh 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




3 


Call the getValueLengthO method 


Result is 03h 




4 


Search 2nd TLV 

Tag = 02h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




5 


Call the getValueLengthO method 


Result is 02h 




6 


Select a TLV (tag 02h) 








Search a wrong tag 

Tag = 03h 
Occurrence = 1 


Result is TLV_NOT_FOUND 




7 


Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown. 




8 


Search a tag with wrong occurrence 

Tag = Olh 
Occurrence = 2 


Result is TLV_NOT_FOUND 




9 


Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown. 




10 


Append a TLV with tag=02h 








Search the TLV 

Tag = 02h 
Occurrence = 2 


Result is 
TLV_FOUND_CR_NOT_SET 




11 


Append a TLV with tag=04h 








Search the TLV 

Tag = 04h 
Occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 




12 


Search tag 81 h 

Tag = 81h 
Occurrence = 1 


Result is TLV_FOUND_CR_SET 




13 


Search tag 84h 

Tag = 84h 
Occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 





6.2.7.9.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,5 


N2 


2,4 


N3 


10, 11 


N4 


6,7,8,9 


N5 


12, 13 


PI 


1 


CI 


Does not apply for 
Proactive Handler 



6.2.7.10 Method getValueLength 

Test Area Reference API_2_PAH_GVLEN 

6.2.7.10.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getValueLength ( ) 

throws ToolkitException 
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Normal execution 

CRRNl: gets and returns the binary length of the value field for the last TLV element which has been found in the 
handler. 

Parameter errors 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitExceptionHANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.7.10.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_PAH_GVLEN_1 .scr 
API_2_PAH_GVLEN_1 .Java 
API_2_PAH_GVLEN_1 .Idr 
API 2 PAH GVLEN l.clr 



6.2.7.10.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Call the initO method 








getValueLength ( ) 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




2 


Call the InitDlsplayTextO method 

length = 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is OOh 




3 


Call the InitDlsplayTextO method 

length = 1 (+ dcs byte) 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is 02h 




4 


Call the InitDisplayTextO method 
length = 7Eh (+ dcs byte) 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is 7Fh 




5 


Call the InitDlsplayTextO method 

length = 7Fh (+ dcs byte) 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is 80h 




6 


Call the InitDisplayTextO method 

length = FOh (maximum text length) 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is Flh 
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6.2.7.10.4 



Test Coverage 



CRR number 


Test case number 


N1 


2, 3, 4, 5, 6 


C1 


Does not apply for 
Proactive Handler 


C2 


1 



6.2.7.1 1 Method getValueByte 

Test Area Reference API_2_PAH_GVBYTS 

6.2.7.1 1 .1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getValueByte (short valueOffset) 
throws ToolkitException 

Normal execution 

CRRNl: Gets a byte from the last TLV element which has been found in the handler and returns its value (1 byte). 

Parameter errors 

CRRPl: if valueOffset is out of the current TLV an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl; if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.7.11.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_PAH_GVB YTS_1 . scr 
API_2_PAH_GVB YTS_1 .j ava 
API_2_PAH_GVB YTS_1 .Idr 
API_2_PAH_GVB YTS_1 .clr 
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6.2.7.11.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Call the InitQ method 

type = FFh 
qualifier = FEh 
destination = FDh 








getValueByte(O) 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




2 


Search TLV 01 h (Command Details TLV) 








getValueByte(3) 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




3 


Search TLV 01 h (Command Details TLV) 








getValueByte(2) 


Result is FEh (qualifier) 




4 


Search TLV 02h (Device Identities TLV) 








getValueByte(O) 


Result is 81 h (Source) 




5 


initDisplayTextO 

buffer = 00 01 ... 7D 

length = 7Eh 

Search TLV ODh (Text String TLV) 








getValueByte(7E) 


Result is 7Dh 




6 


initDisplayTextO 

buffer = 00 01 ... 7D 7E 

length = 7Fh 

Search TLV ODh (Text String TLV) 








getValueByte(7E) 


Result is 7Dh 




7 


getValueByte(7F) 


Result is 7Eh 




8 


InitDisplayTextO 

buffer = 00 01 ... EF 

length = FOh 

Search TLV ODh (Text String TLV) 








getValueByte(FO) 


Result is EFh 





6.2.7.11.4 



Test Coverage 



CRR number 


Test case number 


N1 


3, 4, 5, 6, 7, 8 


P1 


2 


C1 


Does not apply for 
Proactive Handler 


C2 


1 



6.2.7.12 Method copyValue 

Test Area Reference API_2_PAH_CPYVS_BSS 

6.2.7.12.1 Conformance requirement 

The method with following header shall be compliant with its definition in the API. 

public short copyValue (short valueOffset, 

byte[l dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java. lang.NullPointerException, 

Java . lang . Array I ndexOut Of Bounds Except ion, 
ToolkitException 

Normal execution 

CRRNl: copies a part of the last TLV element which has been found, into a destination, buffer. 
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CRRN2: returns dstOffset + dstLength. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException is thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException is thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.7.12.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.12.3 



Test Suite files 

API_2_PAH_CPYVS_BSS_Lscr 
API_2_PAH_CPYVS_BSS_1 .Java 
API_2_PAH_CPYVS_BSS_1 .Idr 
API_2_PAH_CPYVS_BSS_1 .ck 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 
Select a TLV 








copyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


InitDisplayTextQ with length = 15 

Select Text String TLV 








dstOffset > dstBuffer.length 

dstBuffer .length = 5 
dstOffset = 6 
dstLength = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


initDisplayTextO with length = 5 

Select Text String TLV 








valueOffset > Text String Length 

valueOffset = 7 
dstBuffer.length = 15 
dstOffset = 
dstLength = 


ToolkltException.OUT OF TLV 
BOUNDARIES is thrown 




8 


[Select Text String TLV] 


ToolkitException.OUT OF TLV 
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valueOffset < 
valueOffset = -1 
dstBuffer. length = 15 
dstOffset = 
dstLength = 1 


BOUNDARIES is thrown 




9 


[Select Text String TLV] 

dstLength > Text String length 
valueOffset = 
dstBuffer. length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


[Select Text String TLV] 

valueOffset + dstLength > Text String 

length 

valueOffset = 2 

dstBuffer. length = 15 

dstOffset = 

dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Initialise the handler 








copyValueO 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown 




12 


InitDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 

Select Text String TLV 








Successful call 

valueOffset = 
dstBuffer .length = 17 
dstOffset = 
dstLength = 17 


Result of copyValueO is 17 




13 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




14 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

valueOffset = 2 
dstBuffer. length = 20 
dstOffset = 3 
dstLength = 12 


Result of copyValueO is 15 




15 


Compare buffer 

buffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 


Result is OOh 





6.2.7.12.4 



Test Coverage 



CRR number 


Test case number 


N1 


13,15 


N2 


12, 14 


PI 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


CI 


Does not apply for 
Proactive Handler 


C2 


11 



6.2.7.13 Method compareValue 

Test Area Reference API_2_PAH_CPRVS_BSS 

6.2.7.13.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 
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public byte compareValue (short valueOffset, 

byte[] compareBuf f er, 
short compareOf f set , 
short compareLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException^ 
ToolkitException 

Normal execution 

Compares the last found TLV element with a buffer: 

CRRNl: returns if identical. 

CRRN2: returns -1 if the first miscomparing byte in simple TLV List is less than that in compareBuffer. 

CRRN3: returns 1 if the first miscomparing byte in simple TLV List is greater than that in compareBuffer. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if compareLength 
is negative ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.7.13.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.13.3 



Test Suite files 

API_2_PAH_CPRVS_BSS_Lscr 
API_2_PAH_CPRVS_BSS_1 .Java 
API_2_PAH_CPRVS_BSS_1 .Idr 
API_2_PAH_CPRVS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 
Select a TLV 








compareValueO with a null compareBuffer 


NullPointerException is thrown 




2 


InitDisplayTextQ with length = 15 

Select Text String TLV 








compareOffset > compareBuffer.length 

compareBuf fer . length = 5 
compareOffset = 6 
compareLength = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


compareOffset < 

compareBuffer.length = 5 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


compareLength >compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 
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5 


compareOffset + compareLength 
>compareBuffer.length 

compareBuff er . length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


initDisplayTextO with length = 5 
Select Text String TLV 








valueOffset > Text String Length 

valueOffset = 7 
compareBuffer.length = 15 
compareOffset = 
compareLength = 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


[Select Text String TLV] 

valueOffset < 
valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


[Select Text String TLV] 

compareLength > Text String length 
valueOffset = 
compareBuffer.length = 15 
compareOffset = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


[Select Text String TLV] 

valueOffset + compareLength > Text String 

length 

valueOffset = 2 

compareBuffer.length = 15 

compareOffset = 

compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Initialise the handler 








compareValueQ 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




12 


InitDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 

Select Text String TLV 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








Compare buffers 

valueOffset = 
compareOffset = 
compareLength = 17 


Result is OOh 




13 


Initialise compareBuffer 

compareBuffer = 
04 00 01 02 03 

04 05 06 07 08 

05 OA OB OC OD 
OE 10 








Compare buffers with same parameters 


Result is -1 




14 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result is +1 




15 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers 

valueOffset = 2 
compareOffset = 3 


Result is OOh 
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compareLength = 12 






16 


Initialise compareBuffer 

compareBuffer = 
55 55 55 02 01 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




17 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OA OD 
55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




18 


Initialise compareBuffer 

compareBuffer = 
55 55 55 99 03 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 





6.2.7.13.4 



Test Coverage 



CRR number 


Test case number 


N1 


12, 15 


N2 


13,16 


N3 


14, 17, 18 


PI 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


CI 


Does not apply for 
Proactive Handler 


C2 


11 



6.2.7.14 Method findAndCopyValue(byte tag, byte[] dstBuffer, short valueOffset) 

Test Area Reference API 2 PAH FACYB BS 



6.2.7.14.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte[l dstBuffer, 
short dstOffset) 
throws Java. lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 



Normal execution 



CRRN 1 : looks for the first occurrence of a TLV element from the beginning of a TLV list and copy its value into a 
destination buffer. 

CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + length of the 
copied value is returned. 

CRRN4: The search method is comprehension required flag independent. 
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Parameter errors 

CRRPl: if dstBuffer is null NullPointerException shall be thrown. 

CRRP2: if dstOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitExceptionHANDLER_NOT_AVAILABLE. 



6.2.7.14.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.14.3 



Test Suite files 

API_2_PAH_FACYB_BS_1 .scr 
API_2_PAH_FACYB_BS_1 .Java 
API_2_PAH_FACYB_BS_1 .Idr 
API_2_PAH_FACYB_BS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








FindAndCopyVaiueQ with a null dstBuffer 


NullPointerException is thrown 




2 


InitDisplayTextQ with length = 15 








dstOffset > dstBuffer.length 

tag = ODh 

dstBuffer.length = 20 
dstOffset = 21 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


dstOffset < 

dstBuffer.length = 20 
dstOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > dstBuffer.length 

dstBuffer.length = 15 
dstOffset = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


DstOffset + length >dstBuffer.length 

DstBuffer.length = 20 
DstOffset = 5 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


InitDisplayTextO 








Select a TLV (tag 02h) 








findAndCopyValueO 

tag = 03h 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 






Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




7 


InitDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 








Successful call 

Tag = ODh 

DstBuffer.length = 17 
DstOffset = 


Result of findAndcopyValueO is 
17 




8 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




9 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

dstBuffer.length = 20 
dstOffset = 2 


Result of findAndcopyValueO is 
19 




10 


Compare buffer 

buffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 


Result is OOh 
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11 


initDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 








append a 2nd Text String TLV 








Successful call 

tag = ODh 

dstBuffer. length = 17 

dstOffset = 


Result of findAndcopyValueO is 
17 




12 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




13 


InitDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 








Successful call (with tag 8Dh) 

tag = 8Dh 

dstBuffer .length = 17 

dstOffset = 


Result of findAndcopyValueO is 
17 




14 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




15 


Append tag OFh 

buffer = 00 01 ... OF 








Successful call (with tag 8Fh) 

tag = 8Fh 

dstBuffer .length = 16 

dstOffset = 


Result of findAndcopyValueO is 
16 




16 


Compare buffer 

buffer = 00 01 ... OF 


Result is OOh 





6.2.7.14.4 



Test Coverage 



CRR number 


Test case number 


N1 


8, 10, 12 


N2 


6 


N3 


7, 9, 11 


N4 


13, 14, 15, 16 


PI 


1 


P2 


2, 3, 4, 5 


CI 


Does not apply for 
Proactive Handler 



6.2.7.15 Method findAndCopyValue(byte tag, byte occurence, short valueOffset, byte[] 
dstBuffer, short dstOffset, short dstLength) 



Test Area Reference API_2_PAH_FACYBS_BSS 



6.2.7.15.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte occurence, 
short valueOffset, 
byte[] dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang.NullPointerException, 
Java . lang . ArraylndexOutOfBoundsException, 

Toolkit Except ion 

Normal execution 

CRRNl: looks for the indicated occurrence of a TLV element from the beginning of a TLV list and copy its value 
into a destination buffer. 
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CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + dstLength is 
returned. 

CRRN4: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException shall be thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 



6.2.7.15.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.15.3 



Test Suite files 

API_2_PAH_FACYBS_BSS_Lscr 
API_2_PAH_FACYBS_BSS_1 .Java 
API_2_PAH_FACYBS_BSS_1 .Idr 
API_2_PAH_FACYBS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








findAndCopyValueQ with a null dstBuffer 


NullPointerException is thrown 




2 


InitDisplayTextO with length = 15 








dstOffset > dstBuffer.length 

tag = ODh, occurrence = 1 
valueOffset = 
dstBuffer.length = 5 
dstOffset = 6 
dstLength = 


ArraylndexOutOfBoundsExceptio 
n Is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


initDisplayTextO with length = 5 








valueOffset > Text String Length 

tag = ODh, occurrence = 1 
valueOffset = 7 
dstBuffer.length = 15 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 
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dstOffset = 
dstLength = 






8 


valueOffset < 

valueOffset = -1 
dstBuffer .length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > Text String length 

valueOffset = 
dstBuffer .length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > Text String length 

valueOffset = 2 
dstBuffer .length = 15 
dstOffset = 
dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


InitDisplayTextO 








Select a TLV (tag 02h) 








findAndCopyValueO 

tag = ODh 
occurrence = 2 


ToolkitException.UNAVAILABLE 
_ELEIVIENT is thrown 






Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown. 




12 


InitDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 








Successful call 

tag = ODh, occurrence = 1 
valueOffset = 
dstBuffer .length = 17 
dstOffset = 
dstLength = 17 


Result of findAndCopyValueO is 
17 




13 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




14 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

tag = ODh, occurrence = 1 
valueOffset = 2 
dstBuffer. length = 20 
dstOffset = 3 
dstLength = 12 


Result of findAndCopyValueO is 
15 




15 


Compare buffer 

buffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 


Result is OOh 




16 


Append a Text String TLV 

tag = OD 

buffer = 00 11 22 33 44 55 (no specific 

DCS byte) 








Successful call 

tag = ODh, occurrence = 1 
valueOffset = 
dstBuffer. length = 17 
dstOffset = 
dstLength = 17 


Result of findAndCopyValueO is 
17 




17 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




18 


Successful call 

tag = ODh, occurrence = 2 
valueOffset = 
dstBuffer .length = 6 
dstOffset = 
dstLength = 6 


Result of findAndCopyValueO is 
6 




19 


Compare buffer 

buffer = 00 11 22 33 44 55 


Result is OOh 




20 


InitDisplayTextO 
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dcs = 4 

buffer = 00 01 ... OF 








Successful call (witli tag 8Dh) 

tag = 8Dh 
occurrence = 1 
valueOffset = 
dstBuffer. length = 17 
dstOffset = 
dstLength = 17 


Result of flncJAndcopyValueO is 
17 




21 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOli 




22 


Append tag OFh 

buffer = 00 01 ... OF 








Successful call (with tag 8Fh) 

tag = 8Fh 
occurrence = 1 
valueOffset = 
dstBuffer .length = 16 
dstOffset = 
dstLength =16 


Result of findAndcopyValueO is 
16 




23 


Compare buffer 

buffer = 00 01 ... OF 


Result is OOh 





6.2.7.15.4 



Test Coverage 



CRR number 


Test case number 


N1 


13, 15, 17, 19 


N2 


11 


N3 


12, 14, 16, 18 


N4 


20,21,22,23 


PI 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


CI 


Does not apply for 
ProactiveHandler 



6.2.7.16 Method findAndCompareValue(byte tag, byteQ compareBuffer, short 
compareOffset) 



Test Area Reference API_2_PAH_FACRB_BS 



6.2.7.16.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte[] compareBuffer, 
short compareOffset) 
throws Java . lang . NullPointerException, 

Java. lang. Array I ndexOutOfBoundsExcept ion, 
ToolkitException 

Normal execution 

Looks for the first occurrence of a TLV element from beginning of a TLV list and compare its value with a buffer: 

CRRNl: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN2: if the method is successful then the corresponding TLV becomes current. 

CRRN3: if identical returns 0. 

CRRN4: if the first miscomparing byte in simple TLV is less than that in compareBuffer returns -1 . 
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CRRN5: if the first miscomparing byte in simple TLV is greater than that in compareBuffer returns 1 . 
CRRN6: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be 
thrown. 

Context errors 

CRRCl: if the handler is busy an instance of TooUcitException shall be thrown. The reason code shall be 
ToolkitExceptionHANDLER_NOT_AVAILABLE. 



6.2.7.16.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.16.3 



Test Suite files 

API_2_PAH_FACRB_BS_1 .scr 
API_2_PAH_FACRB_BS_1 .Java 
API_2_PAH_FACRB_BS_1 .Idr 
API_2_PAH_FACRB_BS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








findAndCompareValueO with a null dstBuffer 


NullPointerException is thrown 




2 


initDisplayTextQ with length = 15 








compareOffset > compareBuffer.length 

tag = ODh 

compareBuffer.length = 20 
compareOffset = 21 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


compareOffset < 

compareBuffer.length = 20 
compareOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > compareBuffer.length 

compareBuffer.length = 15 
compareOffset = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + length > 

compareBuffer . length 
compareBuffer.length = 20 
compareOffset = 5 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


InitDisplayTextQ 








Select a TLV (tag 02h) 








findAndCompareValueO 

tag = 03h 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 






Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown. 




7 


InitDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








Compare buffers 

tag = ODh 
compareOffset = 


Result is OOh 




8 


Verify current TLV 

getValueLength ( ) 


Result is 17 




9 


Initialise compareBuffer 

compareBuffer = 
04 00 01 ... 10 
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Compare buffers with same parameters 


Result Is -1 




10 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result is +1 




11 


Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOf f set = 2 


Result is OOh 




12 


append a Text String TLV 

tag = ODh 

buffer = 00 11 22 33 44 55 








Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOf f set = 2 


Result is OOh 




13 


Initialise compareBuffer 

compareBuffer = 
55 55 04 01 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOf f set = 2 


Result is -1 




14 


Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OD 10 55 








Compare buffers 

compareOf f set = 2 


Result is +1 




15 


initDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 








Initialise compareBuffer 

CompareBuffer = 04 00 01 ... OF 








Successful call (with tag 8Dh) 

tag = 8Dh 

compareBuf fer . length = 17 

compareOf f set = 


Result is OOh 




16 


Append tag OFh 

buffer = 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 00 01 ... OF 








Successful call (with tag 8Fh) 

tag = 8Fh 

compareBuf fer . length =16 

compareOf f set = 


Result is OOh 




17 


Initialise compareBuffer 

compareBuffer = 00 99 01 03 ... OF 








Successful call (with tag 8Fh) 

tag = 8Fh 

compareBuf fer . length = 16 

compareOf f set = 


Result is +1 
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6.2.7.16.4 



Test Coverage 



CRR number 


Test case number 


N1 


6 


N2 


8 


N3 


7, 11, 12, 17 


N4 


9,13 


N5 


10, 14 


N6 


15, 16 


P1 


1 


P2 


2, 3, 4, 5 


C1 


Does not apply for 
Proactive Handler 



6.2.7.17 Method findAndCompareValue(byte tag, byte occurence, short valueOffset, 
byte[] compareBuffer, short compareOffset, short compareLength) 



Test Area Reference API_2_PAH_FACRBBS_BSS 



6.2.7.17.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte occurence, 
short valueOffset, 
byte[] compareBuffer, 
short compareOffset, 
short compareLength) 
throws Java. lang.NullPointerException, 

Java . lang . Array I ndexOut Of Bounds Except ion, 
ToolkitException 

Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of a TLV list and compare its value with a 
buffer: 

CRRNl: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN2: if the method is successful then the corresponding TLV becomes current. 

CRRN3: if identical is returned. 

CRRN4: if the first miscomparing byte in simple TLV is less than that in compareBuffer -1 is returned. 

CRRN5: if the first miscomparing byte in simple TLV is greater than that in compareBuffer 1 is returned 

CRRN6: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if compareLength 
is negative ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, compareLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

CRRP4: if an input parameter is not valid (e.g. occurence = 0) an instance of ToolkitException shall be thrown. The 
reason code shall be ToolkitException BAD_INPUT_PARAMETER. 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



164 



ETSI TS 101 955 V7.1.0 (2001-06) 



Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitExceptionHANDLER_NOT_AVAILABLE. 



6.2.7.17.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.17.3 



Test Suite files 

API_2_PAH_FACRBBS_BSS_1 .scr 
API_2_PAH_FACRBBS_BSS_1 .Java 
API_2_PAH_FACRBBS_BSS_1 .Idr 
API_2_PAH_FACRBBS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 








findAndCompareValueO with a null 
compareBuffer 


NullPointerException is thrown 




2 


InitDisplayTextQ with length = 15 








compareOffset > compareBuffer.length 

tag = ODh, occurrence = 1 
valueOffset = 
compareBuffer.length = 5 
compareOffset = 6 
compareLength = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 5 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


compareLength >compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 

>compareBuf f er . length 
compareBuffer.length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


initDisplayTextO with length = 5 








valueOffset > Text String Length 

tag = ODh, occurrence = 1 
valueOffset = 7 
compareBuffer.length = 15 
compareOffset = 
compareLength = 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


compareLength > Text String length 

valueOffset = 
compareBuffer.length = 15 
compareOffset = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > Text String 
length 

valueOffset = 2 
compareBuffer.length = 15 
compareOffset = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 
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11 


Invalid parameter 

occurrence = 


ToolkitException.BAD INPUT P 
ARAMETER is thrown 




12 


InitDisplayTextO 








Select a TLV (tag 02h) 








findAndCompareValueQ 

tag = ODh 
occurrence = 2 


ToolkitException.UNAVAILABLE 
_ELEMENT is thrown 






Call the getValueLengthQ method 


Tooll<itException.UNAVAILABLE 
ELEIVIENT is thrown. 




13 


InitDisplayTextO 

dcs = 4 

buffer = 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








findAndCompareValueQ 

tag = ODh, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 17 


Result is OOh 




14 


Verify current TLV 

getValueLength ( ) 


Result is 17 




15 


Initialise compareBuffer 

compareBuffer = 
04 00 01 ... 10 








Compare buffers with same parameters 


Result is -1 




16 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result is +1 




17 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers 

valueOffset = 2 
compareOf f set = 3 
compareLength = 12 


Result is OOh 




18 


Initialise compareBuffer 

compareBuffer = 
55 55 55 02 01 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




19 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OA OD 
55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




20 


append a Text String TLV 

tag = ODh 

buffer = 00 11 22 33 44 55 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








findAndCompareValueQ 

tag = ODh, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 17 


Result is OOh 
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21 


Initialise compareBuffer 

compareBuffer = 
00 11 22 33 44 55 








findAndCompareValueQ 

tag = ODh, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 6 


Result is OOh 




22 


Initialise compareBuffer 

compareBuffer = 
00 11 22 33 44 66 








findAndCompareValueQ 

tag = ODh, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 6 


Result is -1 




23 


InitDisplayTextQ 

dcs = 4 

buffer = 00 01 ... OF 








Initialise compareBuffer 

CompareBuffer = 04 00 01 ... OF 








Successful call (with tag 8Dh) 

tag = 8Dh, occurrence = 1 
valueOffset = 
compareBuffer . length = 17 
compareOf f set = 
compareLength = 17 


Result is OOh 




24 


Append tag OFh 

buffer = 00 01 ... OF 








Initialise compareBuffer 

compareBuffer = 00 01 ... OF 








Successful call (with tag 8Fh) 

tag = 8Fh, occurrence = 1 
valueOffset = 
compareBuffer . length =16 
compareOf f set = 
compareLength =16 


Result is OOh 




25 


Initialise compareBuffer 

compareBuffer =0099 02 ... OF 








findAndCompareValueQ 

tag = ODh, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 17 


Result is +1 





6.2.7.17.4 



Test Coverage 



CRR number 


Test case number 


N1 


12 


N2 


14 


N3 


13, 17, 20,21 


N4 


15, 18,22 


N5 


16, 19 


N6 


23,24 


PI 


1 


P2 


2,3,4,5,6 


P3 


7,8,9, 10 


P4 


11 


CI 


Does not apply for 
Proactive Handler 



6.2.7.18 Method appendArray 

Test Area Reference: API 2 PAH APDA 
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6.2.7.18.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

void appendArray (byte [ ] buffer, short offset, short length) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRN 1 : appends a buffer into the Edithandler buffer 

CRRN2: a successful append does not modify the TLV selected 
Parameters error 

CRRPl: if buffer is null, a java.lang.NullPointerException is thrown 

CRRP2: if offset or length or both would cause access outside the array bounds, or if length is negative, a 
java.lang. ArraylndexOutOfBoundsException is thrown. 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER NOT AVAILABLE 



6.2.7.18.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.18.3 



Test suite files 

API_2_PAH_APDA_1 .scr 
API_2_PAH_APDA_1 .Java 
API_2_PAH_APDA_1 .Idr 
API_2_PAH_APDA_1 .ck 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Null buffer 


NullPointerException is thrown 




2 


offset > buffer.length 

buf fer . length = 5 
offset = 6 
length = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


Offset < 

buffer.length = 5 
offset = -1 
length = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > buffer.length 

buffer.length = 5 
offset = 
length = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


offset + length > buffer.length 

buffer.length = 5 
offset = 3 
length = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


length < 

buffer.length = 5 
offset = 
length = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Handler overflow 

buffer.length = 256 
offset = 
length = 256 


ToolkitException. HANDLER OV 
ERFLOW is thrown 




8 


Initialise handler 
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Select Command Details TLV 








Successful call 

buffer = FF FE ... F8 
offset = 
length = 8 








Verify Current TLV: Call getValueLengthQ 


Result Is 03h 




9 


Clear the handler 








Successful call 

buffer = FF FE ... F8 
offset = 
length = 8 








Call copyO method 








Compare the arrays 

compareBuf fer = FF FE ... F8 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




10 


Successful call 

buffer = 00 01 ... 07 
offset = 2 
length = 6 








Call copyO method 








Compare the arrays 

compareBuffer = FF FE ... F8 02 03 ... 07 


Result of 

javacard.framework.Utll.arrayCo 
mpareO is OOh 




11 


Successful call 

buffer = 11 22 ... 88 
offset = 2 
length = 4 








Call copyO method 








Compare the arrays 

compareBuffer = FF FE ... F8 02 03 ... 07 33 
44 55 66 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




12 


Clear the handler 








Successful call 

buffer = 00 01 ... FC 
offset = 
length = 253 








Call getLengthO method 


result = 253 






Call copyO method 








Compare handler 

compareBuffer = 00 01 ... FC 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 





6.2.7.18.4 



Test Coverage 



CRR number 


Test case number 


N1 


9, 10, 11, 12 


N2 


8 


PI 


1 


P2 


2, 3, 4, 5, 6 


CI 


7 


C2 


Does not apply for 
ProactiveHandler 



6.2.7.1 9 Method appendTLV(byte tag, byte value) 

Test Area Reference: API_2_PAH_APTLBB 

6.2.7.19.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

void appendTLV (byte tag, byte value) 
throws ToolkitException 
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Normal execution 

CRRNl: Appends a TLV element to the current TLV list (1-byte element). 

CRRN2: A successful append does not modify the TLV selected. 
Parameters error 

None 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER NOT AVAILABLE 



6.2.7.19.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.19.3 



Test suite files 

API_2_PAH_APTLBB_Lscr 
API_2_PAH_APTLBB_Ljava 
API_2_PAH_APTLBB_Lldr 
API_2_PAH_APTLBB_Lclr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Call appendArrayO 

length = 251 








Handler Overflow: Call the appendTLVQ 
method 


ToolkitException. HANDLER OV 
ERFLOW is thrown 




2 


Initialise handler 








Select Command Details TLV 








Call the appendTLVQ method 








Verify Current TLV: Call getValueLengthQ 


Result is 03h 




3 


Clear the handler 








Successful call 

tag = 84h 
value = OOh 








Call copyO method 








Compare the arrays 

compareBuf fer = 84 01 00 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




4 


Successful call 

tag = Olh 
value = FEh 








Call copyO method 








Compare the arrays 

compareBuffer = 84 01 00 01 01 FE 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




5 


Clear the handler 








Call appendArrayO 

length = 250 

buffer = 00 81 F7 03 04 ... F9 








Successful call 

tag = 84h 
value = OOh 








Call getLengthO method 


result = 253 
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Call copyO method 








Compare the array 

compareBuffer = 00 81 F7 03 04 ... F9 84 01 
00 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 





6.2.7.19.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,4,5 


N2 


2 


C1 


1 


C2 


Does not apply for 
Proactive Handler 



6.2.7.20 Method appendTLV(byte tag, byte valuel , byte value2) 

Test Area Reference: API_2_PAH_APTLBBB 

6.2.7.20.1 Conformance requirements: 

The method with following header shall be compliant to its definition in the API. 

void appendTLV (byte tag, byte value) 
throws ToolkitException 

Normal execution 

CRRNl: Appends a TLV element to the current TLV list (2-byte element). 

CRRN2: A successful append does not modify the TLV selected. 
Parameters error 

None 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 



6.2.7.20.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test suite files 

API_2_PAH_APTLBBB_1 .scr 
API_2_PAH_APTLBBB_1 .Java 
API_2_PAH_APTLBBB_1 .Idr 
API 2 PAH APTLBBB l.ck 
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6.2.7.20.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Call the InitDlsplayTextO 

length = 250 








Handler Overflow: Call the appendTLVQ 
method 


ToolkitException. HANDLER OV 
ERFLOW is thrown 




2 


Initialise handler 








Select Command Details TLV 








Call the appendTLVQ method 








Verify Current TLV: Call getValueLengthQ 


Result is 03h 




3 


Clear the handler 








Successful call 

tag = 84h 
valuel = OOh 
value2 = Olh 








Call copvO method 








Compare the arrays 

compareBuf fer = 84 02 00 01 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




4 


Successful call 

tag = Olh 
valuel = FEh 
value2 = FDh 








Call copyO method 








Compare the arrays 

compareBuffer = 84 02 00 01 01 02 FE FD 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




5 


Clear the handler 








Call appendArrayO 

length = 249 

buffer = 00 81 F6 03 04 ... F8 








Successful call 

tag = 84h 
valuel = OOh 
value2 = Olh 








Call getLengthO method 


result = 253 






Call copyO method 








Compare handler 

compareBuffer = 00 81 F6 03 04 ... F8 84 02 
00 01 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 





6.2.7.20.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,4,5 


N2 


2 


CI 


1 


C2 


Does not apply for 
Proactive Handler 



6.2.7.21 Method appendTLV(byte tag, byte[ ] value, short valueoffset, short valuelength) 

Test Area Reference: API_2_PAH_APTLBBSS 

6.2.7.21.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

void appendTLV (byte tag. 
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byte[] value, 
short valueoffset, 
short valuelength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
Toolkit Except ion 

Normal execution 

CRRNl: Appends a TLV element to the current TLV list (byte-array element). 

CRRN2: A successful append does not modify the TLV selected. 
Parameters error 

CRRPl: if value is null, a java.lang.NuUPointerException is thrown 

CRRP2: if valueoffset or valuelength or both would cause access outside the array bounds, or if length is negative, a 
java.lang. ArraylndexOutOfBoundsException is thrown. 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 

CRRC3: if valuelength is greater than 255, a ToolkitException is thrown with reason code 
BAD INPUT PARAMETER 



6.2.7.21.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.21.3 



Test suite files 

API_2_PAH_APTLBBSS_1 .scr 
API_2_PAH_APTLBBSS_1 .Java 
API_2_PAH_APTLBBSS_1 .Idr 
API_2_PAH_APTLBBSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Null value 


NullPointerException is thrown 




2 


valueOffset > value.length 

value. length = 5 
valueOffset = 6 
valueLength = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


valueOffset < 

value . length = 5 
valueOffset = -1 
valueLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


valueLength > value.length 

value.length = 5 
valueOffset = 
valueLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


valueOffset + valueLength > value.length 

value.length = 5 
valueOffset = 3 
valueLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


valueLength < 

value.length = 5 
valueOffset = 
valueLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Handler overflow 

value.length = 254 
valueOffset = 
valueLength = 254 


ToolkitException. HANDLER OV 
ERFLOW is thrown 
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8 


Bad parameter 

value. length = 256 
valueOffset = 
valueLength = 256 


ToolkitException.BAD INPUT P 
ARAMETER is thrown 




9 


Initialise handler 








Select Command Details TLV 








Successful call 

tag = 04 

value = FF FE ... F8 
valueOffset = 
valueLength = 8 








Verify Current TLV: Call getvaiueLength ( ) 


Result is 03h 




10 


Clear the handler 








Successful call 

tag = 04 

value = FF FE ... F8 
valueOffset = 
valueLength = 8 








Call copyO method 








Compare the arrays 

compareBuf fer = 04 08 FF FE ... F8 


Result of 

javacard.frameworl<.Util.arrayCo 
mpareO is OOh 




11 


Successful call 

tag = 85h 
value = 00 01 ... 07 
valueOffset = 2 
valueLength = 6 








Call copyO method 








Compare the arrays 

compareBuffer = 04 08 FF FE ... F8 85 06 02 
03 ... 07 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




12 


Successful call 

tag = 01 

value = 11 22 ... 88 
valueOffset = 2 
valueLength = 4 








Call copyO method 








Compare the arrays 

compareBuffer = 04 08 FF FE ... F8 85 06 02 
03 ... 07 01 04 33 44 55 66 


Result of 

javacard.frameworl<.Util.arrayCo 
mpareO is OOh 




13 


Clear the handler 








Successful call 

tag = 04 

value = 00 01 ... 7F 
valueOffset = 
valueLength = 80h 








Call copyO method 








Compare the arrays 

compareBuffer = 04 81 80 00 01. ..7F 


Result of 

javacard.frameworl<.Util.arrayCo 
mpareO is OOh 




14 


Clear the handler 








Successful call 

tag = 04 

value = 00 01 ... F9 
valueOffset = 
valueLength = 250 








Call getLengthO method 


result = 253 






Call copyO method 








Compare handler 

compareBuffer = 04 81 FA 00 01. ..F9 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 
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6.2.7.21.4 



Test Coverage 



CRR number 


Test case number 


N1 


10, 11, 12, 13, 14 


N2 


9 


P1 


1 


P2 


2,3,4,5,6 


C1 


7 


C2 


Does not apply for 
Proactive Handler 


C3 


8 



6.2.7.22 Method appendTLV(byte tag, byte valuel , byte[ ] value2, short value2offset, 
short value2length) 



Test Area Reference: API_2_PAH_APTLBB_BSS 



6.2.7.22.1 



Conformance requirement: 



The method with following header shall be compliant to its definition in the API. 

void appendTLV (byte tag, 
byte valuel 
byte [ ] value2, 
short value2of f set , 
short value21ength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: Appends a TLV element to the current TLV list (1 byte and a byte-array element). 

CRRN2: A successful append does not modify the TLV selected. 
Parameters error 

CRRPl: if value2 is null, a java.lang. NullPointerException is thrown 

CRRP2: if value2offset or value21ength or both would cause access outside the array bounds, or if length is 
negative, a Java. lang. ArraylndexOutOfBoundsException is thrown. 

Context errors 

CRRCl : if the EditHandler buffer is too small to append the requested data, a ToolkitException is thrown with 
reason code HANDLER_OVERFLOW 

CRRC2: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 

CRRC3: if valuelength is greater than 255, a ToolkitException is thrown with reason code 
BAD INPUT PARAMETER 



6.2.7.22.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test suite files 

API_2_PAH_APTLBB_BSS_1 .scr 
API_2_PAH_APTLBB_BSS_1 .Java 
API_2_PAH_APTLBB_BSS_1 .Idr 
API 2 PAH APTLBB BSS Lclr 
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6.2.7.22.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Null value2 


NullPointerException is thrown 




2 


value20ffset > value2.length 

value2 . length = 5 
value20ffset = 6 
value2Length = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


value20ffset < 

value2 . length = 5 
value20ffset = -1 
value2Length = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


value2Length > value2.length 

value2 . length = 5 
value20ffset = 
value2Length = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


value20ffset + value2Length > value2.length 

value2 . length = 5 
value20ffset = 3 
value2Length = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


value2Length < 

value2 . length = 5 
value20ffset = 
value2Length = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Handler overflow 

value2 . length = 254 
value20ffset = 
value2Length = 254 


ToolkitException. HANDLER OV 
ERFLOW is thrown 




8 


Bad parameter 

value2 . length = 256 
value20ffset = 
value2Length = 256 


ToolkitException. BAD INPUT P 
ARAMETER is thrown 




9 


Initialise handler 








Select Command Details TLV 








Successful call 

tag = 04 
valuel = 05 
value2 = FF FE ... F8 
value20ffset = 
value2Length = 8 








Verify Current TLV: Call getValueLengthQ 


Result is 03h 




10 


Clear the handler 








Successful call 

tag = 04 
valuel = 05 
value2 = FF FE ... F8 
value20ffset = 
value2Length = 8 








Call copyO method 








Compare the arrays 

CompareBuffer = 04 09 05 FF FE ... F8 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




11 


Successful call 

tag = 85h 
valuel = 55h 
value2 = 00 01 ... 07 
value20ffset = 2 
value2Length = 6 








Call copyO method 








Compare the arrays 

CompareBuffer = 

04 09 05 FF FE ... F8 

85 07 55 02 03 ... 07 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




12 


Successful call 

tag = 01 
valuel = 44h 
value2 = 11 22 ... 88 
value20ffset = 2 
value2Length = 4 








Call copyO method 








Compare the arrays 

CompareBuffer = 

04 09 05 FF FE ... F8 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 
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85 07 55 02 03 ... 07 
01 05 44 33 44 55 66 






13 


Clear the handler 








Successful call 

tag = 04 
valuel = 00 
value2 = 01 ... 7F 
value20ffset = 
value2Length = 7Fh 








Call copyO method 








Compare the arrays 

compareBuffer = 04 81 80 00 01. ..7F 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOh 




14 


Clear the handler 








Successful call 

tag = 04 
valuel = 00 
value2 = 01 ... F9 
value20ffset = 
value2Length = 249 








Call getLengthO method 


result = 253 






Call copvO method 








Compare handler 

compareBuffer = 04 81 FA 00 01. ..F9 


Result of 

javacard.framework.Util.arrayCo 
mpareO is OOfi 





6.2.7.22.4 



Test Coverage 



CRR number 


Test case number 


N1 


10, 11, 12, 13, 14 


N2 


9 


P1 


1 


P2 


2, 3, 4, 5, 6 


C1 


7 


C2 


Does not apply for 
Proactive Handler 


C3 


8 



6.2.7.23 Method clear 

Test Area Reference: AP1_2_PAH_CLR 

6.2.7.23.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

void clear ( ) 

throws ToolkitException EditHandler 

Normal execution 

CRRNl: Clears the TLV list of an EditHandler 

CRRN2: Resets the current TLV selected. 
Parameters error 

No requirements 
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CRRCl: if the EditHandler buffer is busy, a ToolkitException is thrown with reason code 
HANDLER_NOT_AVAILABLE 



6.2.7.23.2 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.7.23.3 



Test suite files 

API_2_PAH_CLR_1 .scr 
API_2_PAH_CLR_1 .Java 
API_2_PAH_CLR_1 .Idr 
API_2_PAH_CLR_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Initialise the handler 

Select Command Details TLV 
Call the getLengthO method 


Result of getLengthO is not null 






Clear the handler 

Call the getLengthQ method 


Result of getLengthO is 




2 


Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 





6.2.7.23.4 



Test Coverage 



CRR number 


Test case number 


N1 


1 


N2 


2 


C1 


Does not apply for 
Proactive Handler 



6.2.8 Class ProactiveResponseHandler 
6.2.8.1 Method copyAdditionallnformation 

Test Area Reference: API_2_PRH_CPAI_BSS 

6.2.8.1.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short copyAdditionallnformation (byte [ ] dstBuffer^ 

short dstOffset, 

short dstLength) 

throws Java . lang . NullPointerException, 

Java .lang . Array I ndexOut Of Bounds Except ion, 
ToolkitException 

Normal execution 

CRRNl: The copyAdditionalInformation() method shall copy a part of the additional information field from Result 
TLV element in dstBuffer, using dstOffset and dstLength. 

CRRN2: dstBuffer shall only be modified from dstOffset to (dstOffset + dstLength - 1) (included). 

CRRN3: The method returns (dstOffset + dstLength). 

CRRN4: If a Result TLV element is available, it becomes the TLV selected after a call to the method. 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



178 



ETSI TS 101 955 V7.1.0 (2001-06) 



CRRN5: The method shall copy from the first Result TLV. 

Parameter errors 

CRRPl: A NullPointerException shall be thrown if dstBuffer is null. 

CRRP2: An ArraylndexOutOfBoundsException shall be thrown if dstOffset or dstLength or both would cause 
access outside array bounds. 

Context errors 

CRRCl: A ToolkitException.UNAVAILABLE_ELEMENT shall be thrown in case of unavailable Result TLV 
element. 

CRRC2: A ToolkitException.OUT_OF_TLV_BOUND ARIES shall be thrown if dstLength is greater than the value 
field of the available TLV. 



6.2.8.1.3 



Test Suite files 



6.2.8.1.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a DISPLAY TEXT command 

qualifier = 

dcs = 4 

buffer = "Text" 




DISPLAY TEXT Proactive 
command 




Terminal Response with 11 additional bytes 

Result TLV = 03 OC 01 01 23 45 67 89 AB 
CD EF 01 23 45 








NULL as parameter to dstBuffer 

dstBuffer = NULL 


NullPointerException is tlirown 




2 


dstOffset > dstBuffer.length 

dstBuffer .length = 10 
dstOffset = 11 
dstLength = 


ArraylndexOutOfBoundsExceptIo 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 10 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


dstLength > dstBuffer.length 

dstBuffer.length = 10 
dstOffset = 
dstLength =11 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength > dstBuffer.length 

dstBuffer.length = 10 
dstOffset = 6 
dstLength = 5 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 10 
dstOffset = 6 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 5 additional bytes 

Result TLV = 03 06 01 01 23 45 67 89 








Successfull call, dstBuffer is the whole buffer 

dstBuffer.length = 5 
dstOffset = 
dstLength = 5 


result of 

copyAdditionallnformationQ is 
05h. 




8 


Compare dstBuffer using arrayCompare() 

src = {01, 23, 45, 67, 89} 
srcOffset = 00 
dest = dstBuffer 
destOffset = 
length = 5 


result of arrayCompareO is OOh. 
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9 


Call the getValueLengthO method 


Result is 06h. 




10 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 6 additional bytes 

Result TLV = 03 07 01 AB CD EF FE DC BA 








Successfull call, dstBuffer is part of a buffer 

dstBuffer . length = 7 
dstOffset = 2 
dstLength = 5 


result of 

copyAdditionallnformationO is 
07h. 




11 


Compare dstBuffer using arrayCompareQ 

src = {AB, CD, EF, FE, DC} 
srcOffset = 00 
dest = dstBuffer 
destOffset = 2 
length = 5 


result of arrayCompareO is OOh. 




12 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 7 additional bytes 

Result TLV = 03 08 01 FE DC BA 98 76 54 
32 








Successfull call, dstBuffer is part of a buffer 

dstBuffer. length = 7 
dstOffset = 
dstLength = 5 


result of 

copyAdditionallnformationO is 
05h. 




13 


Compare dstBuffer using arrayCompareQ 

src = {FE, DC, BA, 98, 76} 
srcOffset = 00 
dest = dstBuffer 
destOffset = 
length = 5 


result of arrayCompareO is OOh. 




14 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 8 additional bytes 

Result TLV = 03 09 01 00 11 22 33 44 55 
66 77 








Successfull call, dstBuffer is the whole buffer 

dstBuffer .length = 9 
dstOffset = 2 
dstLength = 5 


result of 

copyAdditionallnformationO is 
07h. 




15 


Compare dstBuffer using arrayCompareQ 

src = {00, 11, 22, 33, 44} 
srcOffset = 00 
dest = dstBuffer 
destOffset = 2 
length = 5 


result of arrayCompareO is OOh. 




16 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with F2h additional bytes 

Result TLV = 03 81 F3 01 00 01 02 03... 








Successfull call to the method 

dstBuffer. length = F2h 
dstOffset = 
dstLength = F2h 


result of 

copyAdditionallnformationO is 
F2h. 




17 


Compare dstBuffer using arrayCompareQ 

src = {00, 01, 02, 03, 04...} 
srcOffset = 00 
dest = dstBuffer 
destOffset = 
length = F2h 


result of arrayCompareO is OOh. 




18 


Call the getValueLengthQ method 


Result is F3h. 




19 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 5 additional bytes 
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Result TLV = 03 06 01 00 11 22 33 44 








dstLengtIi > data available 

dstBuffer .length = 6 
dstOffset = 
dstLength = 6 


OUT_OF_TLV_BOUNDARIES 
ToolkitException is thrown 




20 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 5 additional bytes 

Result TLV = 03 06 01 00 11 22 33 44 








Initialise dstBuffer 

dstBuffer = {OOh, Olh, 02h, 03h...} 








Call the copyAdditionallnformationQ method 

dstBuffer .length = 20 
dstOffset = 5 
dstLength = 5 








Compare dstBuffer using arrayCompareQ 

src = { 

OOh, Olh, 02h, 03h, 04h, 
OOh, llh, 22h, 33h, 44h, 
OAh, OBh, OCh, ODh, OEh, 
OFh, lOh, llh, 12h, 13h} 
srcOffset = 
dest = dstBuffer 
destOffset = 
length = 20 


result of arrayCompareO is OOh 




21 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 2 Result TLV 
elements 

1st Result TLV = 03 06 01 01 23 45 67 89 
2nd Result TLV = 03 01 00 








Successfull call to 
copyAdditionallnformationO 

dstBuffer . length = 5 
dstOffset = 
dstLength = 5 


result of 

copyAdditionallnformationO is 
05h. 




22 


Compare dstBuffer using arrayCompareQ 

src = {01, 23, 45, 67, 89} 
srcOffset = 00 
dest = dstBuffer 
destOffset = 
length = 5 


result of arrayCompareO is OOh. 




23 


Call the getValueLengthQ method 


Result is 06h. 




24 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response without Result Simple 
TLV 


ToolkitException.UNAVAILABLE 
_ELEIVIENT is thrown by sendO 






ProactiveResponseHandler, getTheHandler 
call copyAdditionallnformationQ 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown 
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6.2.8.1.4 



Test Coverage 



CRR number 


Test case number 


N1 


8, 11, 13, 15, 17,20,22 


N2 


20 


N3 


7, 10, 12, 14, 16,21 


N4 


9, 18,23 


N5 


21,22,23 


P1 


1 


P2 


2,3,4,5,6 


C1 


24 


C2 


19 



6.2.8.2 Method copyTextString 

Test Area Reference: API_2_PRH_CPTS_BS 



6.2.8.2.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short copyTextString (byte [ ] dstBuffer, 

short dstOffset) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
Toolkit Except ion 

Normal execution 

CRRNl: The copyTextStringO method copies the text string value from the first Text String TLV element, using 
dstBuffer and dstOffset. 

CRRN2: If a Text String TLV element is available, it becomes the TLV selected. 

CRRN3: The method returns (dstOffset + length of copied value). 

Parameter errors 

CRRPl: A NullPointerException shall be thrown if dstBuffer is null. 

CRRP2: A ArraylndexOutOfBoundsException shall be thrown if dstOffset or dstOffset + (length of the TextString 
to be copied, without the Data Coding Scheme included), as specified for the returned value, would cause access 
outside array bounds. 

Context errors 

CRRCl: A ToolkitException.UNAVAILABLE_ELEMENT shall be thrown in case of unavailable Text String TLV 
element. 



6.2.8.2.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_PRH_CPTS_BS_1 .scr 
API_2_PRH_CPTS_BS_1 .Java 
API_2_PRH_CPTS_BS_1 .Idr 
API_2_PRH_CPTS_BS_1 .clr 
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6.2.8.2.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a GET INPUT command 

qualifier = OOh 
dcs = 04h 
buffer = 'Text' 
minRespLength = OOh 
maxRespLength = FFh 




GET INPUT Proactive 
command 




Terminal Response 

Text String TLV = OD 02 04 41 








ProactiveResponseHandler.getTheHandlerO ; 

call the copyTextStringO method with a null 
cIstBuffer 

dstBuffer = null 
dstOffset = 


NullPointerExceptlon is thrown 




2 


Build and send a GET INPUT command 




GET INPUT Proactive 

command 

Proactive 




Terminal Response 

Text String TLV = OD 04 04 "ABC" 








dstOffset + text length > dstBuffer.length 

dstBuffer. length = 04h 
dstOffset = 02h 


Array IndexOutOfBoundsException 
is thrown 




3 


dstOffset < 

dstBuffer.length = 04h 
dstOffset = -1 


ArraylndexOutOfBoundsException 
is thrown 




4 


Build and send a DISPLAY TEXT command 

qualifier = OOh 
dcs = 04h 
buffer = 'Text' 




DISPLAY TEXT 
Proactive command 




Terminal Response without Text String TLV 








ProactiveResponseHandler.getTheHandlerO ; 

call the CopyTextStringO method 


UNAVAILABLE_ELEMENT 
ToolkitException is thrown 




5 


Build and send a GET INPUT command 




GET INPUT Proactive 

command 

Proactive 




Terminal Response with a null Text String tlv 

Text String TLV = OD 00 








Initialise dstBuffer 

dstBuffer = {FOOh, FOlh, F02h, F03h} 








Call the copyTextStringO method 

dstBuffer.length = 04h 
dstOffset = 02h 


Result of copyTextStringO is 02h 




6 


Compare dstBuffer using arrayCompare() 

src = {OFOh, OFlh, 0F2h, 0F3h} 
srcOffset = OOh 
dest = dstBuffer 
destOffset = OOh 
length = 04h 


Result of arrayCompareO is OOh 




7 


Build and send a GET INPUT command 




GET INPUT Proactive 

command 

Proactive 




Terminal Response with text length = Olh 

Text String TLV = OD 02 04 41 








Initialise dstBuffer 

dstBuffer = {OOh, Olh, 02h, 03h} 








Call the copyTextStringO method 

dstBuffer.length = 04h 
dstOffset = OOh 


Result of copyTextStringO is 01 h 
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8 


Compare dstBuffer using arrayCompare() 

src = {41h, Olh, 02h, 03h} 
srcOffset = OOh 
dest = dstBuffer 
destOffset = OOh 
length = 04h 


Result of arrayCompareO is OOh 




9 


Build and send a GET INPUT command 




GET INPUT Proactive 

command 

Proactive 




Terminal Response with text length = 02h 

Text String TLV = OD 03 04 42 43 








Initialise dstBuffer 

dstBuffer = {OOh, Olh, 02h, 03h} 








Call the copyTextStringO method 

dstBuffer. length = 04h 
dstOffset = 02h 


Result of copyTextStringO is 04h 




10 


Compare dstBuffer using arrayCompare() 

src = {OOh, Olh, 42h, 43h} 
srcOffset = OOh 
dest = dstBuffer 
destOffset = OOh 
length = Olh 


Result of arrayCompareO is OOh 




11 


Call the getValueLengthO method 


Result is 03h 




12 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 7Eh 

Text String TLV = OD 7F 04 01 02 ... 7E 








Initialise dstBuffer 

dstBuffer = {OOh, OOh ... OOh} 








Call the copyTextStringO method 

dstBuffer .length = 7Eh 
dstOffset = OOh 


Result of copyTextStringO is 7Eh 




13 


Compare dstBuffer using arrayCompare() 

src = {Olh, ..., 7Eh} 
srcOffset = OOh 
dest = dstBuffer 
destOffset = OOh 
length = 7Eh 


Result of arrayCompareO is OOh 




14 


Call the getValueLengthO method 


Result is 7Fh 




15 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 7Fh 

Text String TLV = OD 81 80 04 01 02 ...7F 








Initialise dstBuffer 

dstBuffer = {OOh, Olh ... FFh} 








Call the copyTextStringO method 

dstBuffer .length = FFh 
dstOffset = lOh 


Result of copyTextStringO is 8Fh 




16 


Compare dstBuffer using arrayCompare() 

src = {OOh, Olh,... OFh, 
Olh, ...7Fh, 8Fh, ... FFh} 
srcOffset = OOh 
dest = dstBuffer 
destOffset = OOh 
length = FFh 


Result of arrayCompareO is OOh 




17 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = EFh 

Text String TLV = OD 81 FO 04 01 02 ... EF 








Initialise dstBuffer 
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dstBuffer = {OOh, OOh ... OOh} 








Call the copyTextStringO method 

dstBuffer .length = FFh 
dstOffset = OOh 


Result of copyTextStringO is EFh 




18 


Compare dstBuffer using arrayCompare() 

src = {Olh, ...EFh, OOh ... OOh } 
srcOffset = OOh 
dest = dstBuffer 
destOffset = OOh 
length = FFh 


Result of arrayCompareO is OOh 




19 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with two Text String TLV 

1st Text String TLV = OD 03 04 42 43 
2nd Text String TLV = OD 02 04 44 








Initialise dstBuffer 

dstBuffer = {OOh, Olh, 02h, 03h} 








Call the copyTextStringO method 

dstBuffer .length = 04h 
dstOffset = 02h 


Result of copyTextStringO is 04h 




20 


Compare dstBuffer using arrayCompare() 

src = {OOh, Olh, 42h, 43h} 
srcOffset = OOh 
dest = dstBuffer 
destOffset = OOh 
length = 04h 


Result of arrayCompareO is OOh 




21 


Call the getValueLengthO method 


Result is 03h 





6.2.8.2.4 



Test Coverage 



CRR number 


Test case number 


N1 


6,8, 10, 13, 16, 18,20 


N2 


11, 14,21 


N3 


5,7,9, 12, 15, 17, 19 


PI 


1 


P2 


2,3 


CI 


4 



6.2.8.3 Method getAdditionallnformationLength 

Test Area Reference: API_2_PRH_GTIL 

6.2.8.3.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getAdditionallnformationLength ( ) 
throws ToolkitException 

Normal execution 

CRRNl: This method returns the length of the additional information field from the first Result TLV in the 
ProactiveResponseHandler. 

CRRN2: After a successful execution of the method, the Result TLV becomes the selected TLV of the 
ProactiveResponseHandler. 
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Parameter errors 



Context errors 



CRRCl: A ToolkitException.UNAVAILABLE_ELEMENT shall be thrown in case of unavailable Result TLV 
element. 



6.2.8.3.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.8.3.3 



Test Suite files 

API_2_PRH_GTIL_l.scr 
API_2_PRH_GTIL_1 .Java 
API_2_PRH_GTIL_1 .Idr 
API_2_PRH_GTIL_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a DISPLAY TEXT command 

qualifier = OOh 
dcs = 04h 
buffer = 'Text' 




DISPLAY TEXT Proactive 
command 




Terminal Response without additional 
information 








ProactiveResponseHandler.getTheHandlerO ; 

call the getAdditionallnformationLengthQ 

method 


Result is OOh 




2 


Call the getValueLengthO method 


Result is Olh 




3 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT 

ProactiveProactive 

command 




Terminal Response with 1 additional byte 

Result TLV = 03 02 02 55 








ProactlveResponseHandler.getTheHandlerQ ; 

call the getAdditionallnformationLengthQ 

method 


Result is Olh 




4 


Call the getValueLengthO method 


Result is 02h 




5 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT 

ProactiveProactive 

command 




Terminal Response with 7Eh additional bytes 

Result TLV = 03 7F 02 55 55 55 ... 








ProactiveResponseHandler.getTheHandlerQ ; 

call the getAdditionallnformationLengthQ 

method 


Result is 7Eh 




6 


Call the getValueLengthO method 


Result is 7Fh 




7 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT 
Proactive command 




Terminal Response with 7Fh additional bytes 

Result TLV = 03 81 80 02 55 55 55 ... 








ProactiveResponseHandler.getTheHandlerO ; 

call the getAdditionallnformationLengthO 

method 


Result is 7Fh 




8 


Call the getValueLengthO method 


Result is 80h 




9 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT 
Proactive command 




Terminal Response with 80h additional bytes 
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Result TLV = 03 81 81 02 55 55 55 ... 








ProactiveResponseHandler.getTheHandlerQ ; 

call the getAdditionallnformationLengthO 

method 


Result is 80h 




10 


Call the getValueLengthO method 


Result is 81 h 




11 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT 
Proactive command 




Terminal Response with F2h additional bytes 

Result TLV = 03 81 F3 02 55 55 55 ... 








ProactiveResponseHandler.getTheHandlerQ ; 

call the getAdditionallnformationLengthO 

method 


Result is F2h 




12 


Call the getValueLengthO method 


Result is F3h 




13 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT 
Proactive command 




Terminal Response with 2 Result TLV 

1st Result TLV = 03 03 02 01 23 
2nd Result TLV = 03 01 00 








ProactiveResponseHandler.getTheHandlerQ ; 

call the getAdditionallnformationLengthQ 

method 


Result is 02h 




14 


Call the getValueLengthO method 


Result is 03h 




15 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT 
Proactive command 




Terminal Response without Result Simple 
TLV 


ToolkitException.UNAVAILABLE_E 
LEMENT is thrown by sendQ 






Get ProactiveResponseHandler 








Call the getAdditionallnformationLengthO 
method 


ToolkitException.UNAVAILABLE_E 
LEMENT is thrown by 
getAdditionallnformationLength () 





6.2.8.3.4 



Test Coverage 



CRR number 


Test case number 


N1 


1, 3, 5, 7,9, 11, 13 


N2 


2,4,6,8, 10, 12, 14 


CI 


15 



6.2.8.4 Method getGeneralResult 

Test Area Reference: API_2_PRH_GTGR 

6.2.8.4.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getGeneralResult ( ) 

throws ToolkitException 

Normal execution 

CRRNl: This method returns the general result of a proactive command. 

CRRN2: After a successful execution of the method, the Result TLV becomes the selected TLV of the 
ProactiveResponseHandler. 
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Parameter errors 

Context errors 

CRRCl: A ToolkitException.UNAVAILABLE_ELEMENT shall be thrown in case of unavailable Result TLV 
element. 

CRRC2: A ToolkitException.OUT_OF_TLV_BOUND ARIES shall be thrown if the general result byte is missing 
in the Result Simple TLV. 



6.2.8.4.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.8.4.3 



Test Suite files 

API_2_PRH_GTGR_1 .scr 
API_2_PRH_GTGR_1 .Java 
API_2_PRH_GTGR_1 .Idr 
API_2_PRH_GTGR_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a DISPLAY TEXT command 

qualifier = OOh 
dcs = 04h 
buffer = 'Text' 




DISPLAY TEXT Proactive 
command 




Terminal Response with General Result = 00 
(command performed successfully) 








ProactiveResponseHandler.getTheHandlerQ 
Call the getGeneralResultO method 


Result of getGeneralResultO is OOh 




2 


Call the getValueLengthO method 


Result is 01 h 




3 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with General Result = 01, 

without Additional information on result 

(command performed with partial 

comprehension) 








ProactiveResponseHandler.getTheHandlerQ 
Call the getGeneralResultO method 


Result of getGeneralResultO is 01 h 




4 


Call the getValueLengthO method 


Result is 01 h 




5 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with General Result = 01, 
with Additional information on result 

Result TLV = 03 02 01 55 (command 
performed with partial comprehension) 








ProactiveResponseHandler.getTheHandlerO 

Call the getGeneralResultO method 


Result of getGeneralResultO is 01 h 




6 


Call the getValueLengthO method 


Result is 02h 




7 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with General Result = 02 

Result TLV = 03 04 02 65 43 21 (Missing 
information) 








ProactiveResponseHandler.getTheHandlerO 

Call the getGeneralResultO method 


Result of getGeneralResultO is 02h 
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8 


Call the getValueLengthO method 


Result is 04h 




9 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 7Fh additional bytes 

Result TLV = 03 81 80 02 55 55 55 ... 








ProactiveResponseHandler.getTheHandlerQ ; 
call the getGeneralResultQ method 


Result is 02h 




10 


Call the getValueLengthO method 


Result is 80h 




11 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 2 Result TLV 

1st Result TLV = 03 02 02 12 
2nd Result TLV = 03 03 03 34 56 








ProactiveResponseHandler.getTheHandlerO ; 

call the getGeneralResult method 


Result is 02h 




12 


Call the getValueLengthO method 


Result is 02h 




13 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response without Result Simple 
TLV 


ToolkitException.UNAVAILABLE_E 
LEMENT is thrown by send() 






ProactiveResponseHandler.getTheHandlerO ; 
call the getGeneralResultQ method 


UNAVAILABLE_ELEMENT 
ToolkitException is thrown 




14 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response without General Result 
Byte in Result Simple TLV 


ToolkitException.UNAVAILABLE_E 
LEMENT is thrown by send() 






ProactiveResponseHandler.getTheHandlerO ; 

call the getGeneralResult method 
Result TLV = 03 00 


OUT_OF_TLV_BOUNDARIES 
ToolkitException is thrown 





6.2.8.4.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,3, 5, 7, 9, 11 


N2 


2,4,6,8, 10, 12 


CI 


13 


C2 


14 



6.2.8.5 Method getltem Identifier 

Test Area Reference: API_2_PRH_GTII 

6.2.8.5.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getltemldentif ier ( ) 

throws ToolkitException 
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Normal execution 

CRRN 1 : The method returns the item identifier byte value from the first Item Identifier TLV element. 
CRRN2: If an Item Identifier TLV element is available, it becomes the TLV selected. 

Parameter errors 

Context errors 

CRRCl: A ToolkitException.UNAVAILABLE_ELEMENT shall be thrown in case of unavailable Item Identifier 
TLV element. 

CRRC2: A ToolkitException.OUT_OF_TLV_BOUND ARIES shall be thrown if the item identifier byte is missing 
in the Item Identifier Simple TLV. 



6.2.8.5.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.8.5.3 



Test Suite files 

API_2_PRH_GTII_1 .scr 
API_2_PRH_GTII_1 .Java 
API_2_PRH_GTII_1 .Idr 
API_2_PRH_GTII_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response (no Item Identifier TLV 
available) 








Call to getltemldentifierO with unavailable 
Item Identifier TLV 


UNAVAILABLE_ELEMENT 
ToolkitException is thrown 




2 


Build and send a SELECT ITEM command 
with2items(ID=01,02) 




SELECT ITEM Proactive 
command 




Terminal Response with Item 1 selected 

Item Identifier TLV = 10 01 01 








Call the getltemldentifierO method 


Result is Olh 




3 


Call the getValueByteO method 

valueOffset = OOh 


Result is 01 h 




4 


Build and send a SELECT ITEM command 
with 3 items (ID=03, 05, 07) 




SELECT ITEM Proactive 
command 




Terminal Response with Item 5 selected 

Item Identifier TLV = 10 01 05 








Call the getltemldentifierO method 


Result is 05h 




5 


Call the getValueByteO method 

valueOffset = OOh 


Result is 05h 




6 


Build and send a SELECT ITEM command 
with 3 items (ID=FDh, FEh, FFh) 




SELECT ITEM Proactive 
command 




Terminal Response with Item FFh selected 

Item Identifier TLV = 10 01 FF 








Call the getltemldentifierO method 


Result is FFh 




7 


Call the getValueByteO method 

valueOffset = OOh 


Result is FFh 




8 


Build and send a SELECT ITEM command 




SELECT ITEM Proactive 
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with 3 items (ID=FDh, FEh, FFh) 




command 




Terminal Response with 2 Item Identifier tlv 

1st Item Identifier TLV = 10 01 FFh 
2nd Item Identifier TLV = 10 01 FEh 








Call the getltemldentifierO method 


Result is FFh 




9 


Call the getValueByteO method 

valueOffset = OOh 


Result is FFh 




10 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response without item identifier in 
the Item Identifier Simple TLV 

Item Identifier TLV = 10 00 








Call to getltemldentifierO 


OUT_OF_TLV_BOUNDARIES 
ToolkitException is thrown 





6.2.8.5.4 



Test Coverage 



CRR number 


Test case number 


N1 


2, 4, 6, 8 


N2 


3, 5, 7, 9 


C1 


1 


C2 


10 



6.2.8.6 Method getTextStringCodingScheme 

Test Area Reference: API_2_PRH_GTCS 

6.2.8.6.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getTextStringCodingScheme ( ) 

throws ToolkitException 

Normal execution 

CRRNl: This method returns the data coding scheme from the first Text String TLV element. 
CRRN2: If a Text String TLV element is available, it becomes the TLV selected. 

Parameter errors 

Context errors 

CRRCl: A ToolkitException.UNAVAILABLE_ELEMENT shall be thrown in case of unavailable Text String TLV 
element. 

CRRC2: A ToolkitException.OUT_OF_TLV_BOUND ARIES shall be thrown if the Text String TLV is present 
with a length of 0. 



6.2.8.6.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_PRH_GTCS_1 .scr 
API_2_PRH_GTCS_1 .Java 
API_2_PRH_GTCS_1 .Idr 
API 2 PRH GTCS l.clr 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



191 



ETSI TS 101 955 V7.1.0 (2001-06) 



6.2.8.6.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response (no Text String TLV 
element available) 








Call to getTextStringCodingSchemeO with 
unavailable Text String TLV 


UNAVAILABLE_ELEMENT 
ToolkitException is thrown 




2 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with a null Text String TLV 

Text String TLV = OD 00 








Call the getTextStringCodingSchemeO 
method 


OUT_OF_TLV_BOUNDARIES 
ToolkitException is thrown 




3 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 01 h, dcs 

= 04h 

Text String TLV = OD 02 04 "A" 








Call the getTextStringCodingSchemeO method 


Result is 04h 




4 


Call the getValueLengthO method 


Result is 02h 




5 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 02h, 
DCS = OOh 

Text String TLV = OD 03 00 "BB" 








Call the getTextStringCodingSchemeO 
method 


Result is OOh 




6 


Call the getValueLengthO method 


Result is 03h 




7 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 7Eh, 
DCS = 08h 

Text String TLV = OD 7F 08 01 02 ... 7E 








Call the getTextStringCodingSchemeO 
method 


Result is 08h 




8 


Call the getValueLengthO method 


Result is 7Fh 




9 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 7Fh, 
DCS = 04h 

Text String TLV = OD 81 80 04 01 02 ... 7F 








Call the getTextStringCodingSchemeO 
method 


Result is 04h 




10 


Call the getValueLengthO method 


Result is BOh 
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11 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = EFh, 
DCS = 08h 

Text String TLV = OD 81 FO 08 01 02 ... EE 
EF 








Call the getTextStringCodingSchemeQ 
method 


Result is 08h 




12 


Call the getValueLengthO method 


Result is FOh 




13 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with 2 Text String TLV 

1st Text String TLV = OD 02 04 41 
2nd Text String TLV = OD 03 08 42 43 








Call the getTextStringCodingSchemeQ 
method 


Result is 04li 




14 


Call the getValueLengthO method 


Result is 02h 





6.2.8.6.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,5,7, 9,11,13 


N2 


4,6,8, 10, 12, 14 


CI 


1 


C2 


2 



6.2.8.7 Method GetTextStringLength 

Test Area Reference: API_2_PRH_GTTL 

6.2.8.7.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getTextStringLength ( ) 

throws ToolkitException 

Normal execution 

CRRNl: The getTextStringLength() method returns the text string length value from the first Text String TLV 
element. 

CRRN2: If a Text String TLV element is available, it becomes the TLV selected. 
Parameter errors 

Context errors 

CRRCl: A ToolkitException.UNAVAILABLE_ELEMENT shall be thrown in case of unavailable Text String TLV 
element. 
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6.2.8.7.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.8.7.3 



Test Suite files 

API_2_PRH_GTTL_1 .scr 
API_2_PRH_GTTL_1 .Java 
API_2_PRH_GTTL_1 .Mr 
API_2_PRH_GTTL_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response (no Text String TLV 
element available) 








Call to getTextStringLengthQ with unavailable 
Text String TLV 


UNAVAILABLE_ELEMENT 
ToolkitException is thrown 




2 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with a null Text String TLV 

Text String TLV = OD 00 








Call the getTextStringLengthO method 


Result is OOh 




3 


Call the getValueLengthO method 


Result is OOh 




4 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 01 h, 
DCS = 04h 

Text String TLV = OD 02 04 "A" 








Call the getTextStringLengthO method 


Result is 01 h 




5 


Call the getValueLengthO method 


Result is 02h 




6 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 02h, 
DCS = OOh 

Text String TLV = OD 03 00 "BB" 








Call the getTextStringLengthO method 


Result is 02h 




7 


Call the getValueLengthO method 


Result is 03h 




8 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 7Eh, 
DCS = 08h 

Text String TLV = OD 7F 08 01 02 ... 7E 








Call the getTextStringLengthO method 


Result is 7Eh 




9 


Call the getValueLengthO method 


Result is 7Fh 




10 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = 7Fh, 
DCS = 04h 

Text String TLV = OD 81 80 04 01 02 ... 7F 








Call the getTextStringLengthO method 


Result is 7Fh 
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11 


Call the getValueLengthO method 


Result is 80h 




12 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with text length = EFh, 
DCS = 04h 

Text String TLV = OD 81 FO 04 01 02 ... EE 
EF 








Call the getTextStringLengthO method 


Result is EFh 




13 


Call the getValueLengthO method 


Result is FOh 




14 


Build and send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response with 2 Text String TLV 

1st Text String TLV = OD 02 04 41 
2ncl Text String TLV = OD 03 08 42 43 








Call the getTextStringLengthO method 


Result is Olh 




15 


Call the getValueLengthO method 


Result is 02h 





6.2.8.7.4 



Test Coverage 



CRR number 


Test case number 


1 


2,4,6, 8, 10, 12, 14 


2 


3,5,7, 9, 11, 13, 15 


3 


1 



6.2.8.8 Method getTheHandler 

Test Area Reference: API_2_PRH_GTHD 

6.2.8.8.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public static ProactiveResponseHandler getTheHandler ( ) 

throws ToolkitException 

Normal execution 

CRRNl: The method shall return the single system instance of the ProactiveHandler class. 
CRRN2: The EnvelopeHandler is a Temporary JCRE Entry Point Object 

Parameter errors 

Context errors 

CRRCl: The method shall throw ToolkitException.HANDLER_NOT_AVAILABLE if the handler is busy. 

6.2.8.8.3 Test Suite files 

Test Script: API_2_PRH_GTHD_l.scr 

Test Applet: API_2_PRH_GTHD_l.java 

Load Script: API_2_PRH_GTHD_l.ldr 
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Clean-up Script: 



API_2_PRH_GTHD_1 .clr 



6.2.8.8.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a Proactive Command 




Proactive Command 




Terminal Response 








getTheHandlerO twice 


The returned objects shall be the 
same 




2 


getTheHandlerO 


The reference shall be a 
ProactiveResponseHandler 




3 


getTheHandlerO 


The reference shall not be null 





6.2.8.8.4 



Test Coverage 



CRR number 


Test case number 


N1 


1, 2, 3 


N2 


To be checked in 

Framework tests and 

insert here cross 

reference 


C1 


To be checked in 

Framework tests and 

insert here cross 

reference 



6.2.8.9 Method getLength 

Test Area Reference API_2_PRH_GLEN 

6.2.8.9.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getLength () 

throws ToolkitException 

Normal execution 

CRRNl: returns the length in bytes of the TLV list. 

Parameter errors 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException.HANDLER_NOT_AVAILABLE. 



6.2.8.9.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_PRH_GLEN_1 .scr 
API_2_PRH_GLEN_1 .Java 
API_2_PRH_GLEN_1 .Idr 
API_2_PRH_GLEN_1 .clr 
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6.2.8.9.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Build and send a Display Text command 




DISPLAY TEXT Proactive 
command 




Terminal Response without additional 
information in General Result TLV 








ProactiveResponseHandler.getTheHandlerQ 

getLength () 


Result of getLengthO is 12 




2 


Build and send a Display Text command 




DISPLAY TEXT Proactive 
command 




Terminal Response with F2h additional 
information in General Result TLV 








ProactiveResponseHandler.getTheHandlerQ 
getLengthO 


Result of getLengthO is FFh 





6.2.8.9.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2 


C1 


Does not apply for 

Proactive Response 

Handler 



6.2.8.10 Method copy 

Test Area Reference API_2_PRH_COPY_BSS 



6.2.8.10.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short copy (byte [] dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: copies the simple TLV list contained in the handler to the destination byte array. 
CRRN2: returns dstOffset + dstLength. 

Parameter errors 

CRRPl: if dstBuffer is null a NullPointerException is thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative, an 
ArraylndexOutOfBoundsException is thrown. 

CRRP3: if dstLength is grater than the length of the simple TLV List, an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException. OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

6.2.8.10.3 Test Suite files 

Test Script: API_2_PRH_COPY_BSS_l.scr 

Test Applet: API_2_PRH_C0PY_BSS_l.java 
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Load Script: 
Clean-up Script: 

6.2.8.10.3 



API_2_PRH_COPY_BSS_l .Idr 
API_2_PRH_C0P Y_BSS_1 .clr 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response without Additional 
Information in General Result TLV: 

81 03 01 21 00 02 02 82 81 03 01 00 








ProactiveResponseHandler.getTheHandlerQ 
copyO with NULL as parameter to dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

dstBuffer . length = 5 
dstOffset = 6 
dstLength = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


dstLength > dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength > dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


dstLength > length of the simple TLV list 

dstBuffer.length = 13 
dstOffset = 
dstLength = 13 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


Successful call, dstBuffer is the whole buffer 

dstBuffer.length = 12 
dstOffset = 
dstLength = 12 


Result of copyO is 12 




9 


Compare the buffer with buffer: 

81 03 01 21 00 02 02 82 81 03 01 00 


Result of arrayCompareO is 




10 


Successful call, dstBuffer is part of a buffer 

dstBuffer.length = 20 
dstOffset = 3 
dstLength = 12 


Result of copyQ is 15 




11 


Compare the whole buffer 

Reference = 

00 01 02 

81 03 01 21 00 

02 02 82 81 

03 01 00 

OF 10 11 12 13 


Result of arrayCompareO is 




12 


Initialize dstBuffer 

dstBuffer = OOh Olh 02h ... 13h 








Successful call, dstBuffer is part of a buffer 

dstBuffer.length = 20 
dstOffset = 3 
dstLength = 9 


Result of copyQ is 12 




13 


Compare the whole buffer 

Reference = 

00 01 02 

81 03 01 21 00 

02 02 82 81 

OC OD OE 

OF 10 11 12 13 


Result of arrayCompareO is 
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6.2.8.10.4 



Test Coverage 



CRR number 


Test case number 


N1 


9, 11, 13 


N2 


8, 10, 12 


P1 


1 


P2 


2, 3, 4, 5, 6 


P3 


7 


C1 


Does not apply for 

Proactive Response 

Handler 



6.2.8.11 Method findTLV 

Test Area Reference API_2_PRH_FINDBB 

6.2.8.1 1 .1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte findTLV (byte tag, byte occurrence) 
throws ToolkitException 

Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of the TLV list (handler buffer): 

CRRNl: the method is successful if the required occurrence exists then the corresponding TLV becomes current. 

CRRN2: if the method is successful then it returns TLV_FOUND_CR_SET when Comprehension Required flag is 

set. 

CRRN3: if the method is successful then it returns TLV_FOUND_CR_NOT_SET when Comprehension Required 
flag is not set. 

CRRN4: if the required occurrence of the TLV element does not exist, the current TLV is no longer defined and 
TLV_NOT_FOUND is returned. 

CRRN5: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl : if an input parameter is not valid (e.g. occurrence = 0) an instance of ToolkitException shall be thrown. 
The reason code shall be ToolkitException BAD_INPUT_PARAMETER. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 



6.2.8.11.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_PRH_FINDBB_1 .scr 
API_2_PRH_FINDBB_1 .Java 
API_2_PRH_FINDBB_1 .Idr 
API 2 PRH FINDBB l.clr 
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6.2.8.11.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a DISPLAY TEXT command 




DISPLAY TEXT Proactive 
command 




Terminal Response with 2 General Result TLV 

81 03 01 21 00 

82 02 82 81 
03 01 00 

03 02 01 12 








findTLVO with Invalid input parameter 

occurrence = 


ToolkitException.BAD INPUT P 
ARAMETER is thrown 




2 


Search 1st TLV 

tag = Olh 
occurrence = 1 


Result is TLV_FOUND_CR_SET 




3 


Call the getValueLengthO method 


Result is 03h 




4 


Search 2nd TLV 

tag = 02h 
occurrence = 1 


Result is TLV_FOUND_CR_SET 




5 


Call the getValueLengthO method 


Result is 02h 




6 


Select a TLV (tag 02h) 








Search a wrong tag 

tag = 04h 
occurrence = 1 


Result is TLV_NOT_FOUND 




7 


Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT shall be thrown 




8 


Search a tag with wrong occurrence 

tag = Olh 
occurrence = 2 


Result is TLV_NOT_FOUND 




9 


Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEMENT shall be thrown. 




10 


Search 3rd TLV 

tag = 03h 
occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 




11 


Call the getValueLengthO method 


Result is Olh 




12 


Search 3rd TLV 

tag = 03h 
occurrence = 2 


Result is 
TLV_FOUND_CR_NOT_SET 




13 


Call the getValueLengthO method 


Result is 02h 




14 


Search tag 83h 

tag = 83h 
occurrence = 1 


Result is 
TLV_FOUND_CR_NOT_SET 




15 


Search tag 82h 

tag = 82h 
occurrence = 1 


Result is TLV_FOUND_CR_SET 





6.2.8.11.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,5, 11, 13 


N2 


2,4 


N3 


10, 12 


N4 


6,7,8,9 


N5 


14,15 


PI 


1 


CI 


Does not apply for 

Proactive Response 

Handler 



6.2.8.12 Method getValueLength 

Test Area Reference API_2_PRH_GVLEN 
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6.2.8.12.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public short getValueLength ( ) 

throws ToolkitException 

Normal execution 

CRRNl: gets and returns the binary length of the value field for the last TLV element which has been found in the 
handler. 

Parameter errors 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 

6.2.8.12.3 Test Suite files 

Test Script: API_2_PRH_GVLEN_l.scr 

Test Applet: API_2_PRH_GVLEN_l.java 

Load Script: API_2_PRH_GVLEN_l.ldr 

Clean-up Script: API_2_PRH_GVLEN_Lclr 
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6.2.8.12.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response 

Text String TLV = OD 00 








ProactiveResponseHandler.getTheHandlerQ 

getValueLength ( ) 


ToolkitException.UNAVAILABLE 
_ELEMENT is thrown 




2 


Search TLV ODh 








getValueLength ( ) 


Result is OOli 




3 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response 

Text String TLV = OD 02 04 41 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is 02li 




4 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 7Eh 

Text String TLV = OD 7F 04 01 02 ... 7E 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is 7Fli 




5 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 7Fh 

Text String TLV = OD 81 80 04 01 02 ... 7E 
7F 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is 80h 




6 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = EFh 

Text String TLV = OD 81 FO 04 01 02 ... EF 








Search TLV ODh (Text String TLV) 








getValueLength ( ) 


Result is FOh 





6.2.8.12.4 



Test Coverage 



CRR number 


Test case number 


N1 


2,3,4,5,6 


C1 


Does not apply for 

Proactive Response 

Handler 


02 


1 



6.2.8.13 Method getValueByte 

Test Area Reference API_2_PRH_GVBYTS 

6.2.8.13.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte getValueByte (short valueOffset) 
throws ToolkitException 
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Normal execution 

CRRNl: Gets a byte from the last TLV element which has been found in the handler and returns its value (1 byte). 

Parameter errors 

CRRPl: if valueOffset is out of the current TLV an instance of ToolkitException shall be thrown. The reason code 
shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.8.13.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.8.13.3 



Test Suite files 

API_2_PRH_GVBYTS_1 .scr 
API_2_PRH_GVBYTS_1 .Java 
API_2_PRH_GVB YTS_1 .Idr 
API_2_PRH_GVB YTS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 7Eh 

Text String TLV = OD 7F 04 01 02 ... 7E 








ProactiveResponseHandler.getTheHandlerQ 








getValueByte(O) 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




2 


Search TLV 01 h (Command Details TLV) 








getValueByteO) 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




3 


Search TLV 01 h (Command Details TLV) 








getValueByte(2) 


Result is OOh (qualifier) 




4 


Search TLV 02h (Device Identities TLV) 








getValueByte (0) 


Result is 82h (Source) 




5 


Search TLV ODh (Text String TLV) 








getValueByte (7E) 


Result is 7Eh 




6 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = EFh 

Text String TLV = OD 81 FO 04 01 02 ... 7E 
7F ... EF 








Search TLV ODh (Text String TLV) 








getValueByte (7E) 


Result is 7Eh 




7 


getValueByte (7F) 


Result is 7Fh 




8 


getValueByte (EF) 


Result is EFh 
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6.2.8.13.4 



Test Coverage 



CRR number 


Test case number 


N1 


3,4,5,6,7,8 


P1 


2 


CI 


Does not apply for 

Proactive Response 

Handler 


C2 


1 



6.2.8.14 Method copyValue 

Test Area Reference API_2_PRH_CPYVS_BSS 



6.2.8.14.1 



Conformance requirement 



The method with following header shall be compliant with its definition in the API. 

public short copyValue (short valueOffset, 

byte[] dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: copies a part of the last TLV element which has been found, into a destination, buffer. 
CRRN2: returns dstOffset + dstLength. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException is thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException is thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.8.14.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 



Test Suite files 

API_2_PRH_CPYVS_BSS_1 .scr 
API_2_PRH_CPYVS_BSS_l.java 
API_2_PRH_CPYVS_BSS_l.ldr 
API_2_PRH_CPYVS_BSS_1 .clr 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



204 



ETSI TS 101 955 V7.1.0 (2001-06) 



6.2.8.14.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 5 

Text String TLV = OD 06 04 01 02 ... 05 








ProactiveResponseHandler.getTheHandlerO 

Select Text String TLV 








copyValueO with a null dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

dstBuffer . length = 5 
dstOffset = 6 
dstLength = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength >dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


valueOffset > Text String Length 

valueOffset = 7 
dstBuffer.length = 15 
dstOffset = 
dstLength = 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > Text String length 

valueOffset = 
dstBuffer.length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > Text String length 

valueOffset = 2 
dstBuffer.length = 15 
dstOffset = 
dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler . getTheHandler 








copyValue () 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




12 


Select Text String TLV 








Successful call 

valueOffset = 
dstBuffer.length = 17 
dstOffset = 
dstLength = 17 


Result of copyValueO is 17 




13 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




14 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

valueOffset = 2 


Result of copyValueO is 15 
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dstBuffer. length = 20 
dstOffset = 3 
dstLength = 12 






15 


Compare buffer 

buffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 


Result is OOh 





6.2.8.14.4 



Test Coverage 



CRR number 


Test case number 


N1 


13,15 


N2 


12, 14 


PI 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


CI 


Does not apply for 

Proactive Response 

Handler 


02 


11 



6.2.8.15 Method compareValue 

Test Area Reference API_2_PRH_CPRVS_BSS 

6.2.8.15.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte compareValue (short valueOffset, 

byte[] compareBuf f er, 
short compareOf f set , 
short compareLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

Compares the last found TLV element with a buffer: 

CRRNl: returns if identical. 

CRRN2: returns -1 if the first miscomparing byte in simple TLV List is less than that in compareBuffer. 

CRRN3: returns 1 if the first miscomparing byte in simple TLV List is greater than that in compareBuffer. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if compareLength 
is negative ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 
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CRRC2: in case of unavailable TLV element an instance of ToolkitException shall be thrown. The reason code shall 
be ToolkitException UNAVAILABLE_ELEMENT. 



6.2.8.15.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.8.15.3 



Test Suite files 

API_2_PRH_CPRVS_BSS_1 .scr 
API_2_PRH_CPRVS_BSS_1 .Java 
API_2_PRH_CPRVS_BSS_1 .Idr 
API_2_PRH_CPRVS_BSS_1 .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 5 

Text String TLV = OD 06 04 01 02 ... 05 








ProactiveResponseHandler.getTheHandlerQ 

Select Text String TLV 








compareValueO with a null compareBuffer 


NullPointerException is tlirown 




2 


compareOffset > compareBuffer.length 

compareBuff er . length = 5 
compareOffset = 6 
compareLength = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 5 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


compareLength >compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 
>compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


valueOffset > Text String Length 

valueOffset = 7 
compareBuffer.length = 15 
compareOffset = 
compareLength = 


ToolkJtException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkJtException.OUT OF TLV 
BOUNDARIES is thrown 




9 


compareLength > Text String length 

valueOffset = 
compareBuffer.length = 15 
compareOffset = 
compareLength = 7 


ToolkJtException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > Text String 
length 

valueOffset = 2 
compareBuffer.length = 15 
compareOffset = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 
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Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler . getTheHandler ( ) 








compareValue () 


ToolkitException.UNAVAILABLE 
ELEMENT is thrown 




12 


Select Text String TLV 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








Compare buffers 

valueOffset = 
compareOf f set = 
compareLength = 17 


Result is OOli 




13 


Initialise compareBuffer 

compareBuffer = 
04 00 01 ... 10 








Compare buffers with same parameters 


Result is -1 




14 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result is +1 




15 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers 

valueOffset = 2 
compareOf f set = 3 
compareLength = 12 


Result is OOli 




16 


Initialise compareBuffer 

compareBuffer = 
55 55 55 02 01 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




17 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OA OD 
55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 





6.2.8.15.4 



Test Coverage 



CRR number 


Test case number 


N1 


12, 15 


N2 


13, 16 


N3 


14, 17 


PI 


1 


P2 


2,3,4,5,6 


PS 


7,8,9, 10 


CI 


Does not apply for 

Proactive Response 

Handler 


C2 


11 



6.2.8.1 6 Method findAndCopyValue(byte tag, byte[] dstBuffer, short valueOffset) 

Test Area Reference API_2_PRH_FACYB_BS 
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6.2.8.16.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte[] dstBuffer, 
short dstOffset) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 
ToolkitException 

Normal execution 

CRRNl: looks for the first occurrence of a TLV element from the beginning of a TLV list and copy its value into a 
destination buffer. 

CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + length of the 
copied value is returned. 

CRRN4: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException shall be thrown. 

CRRP2: if dstOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be thrown. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 



6.2.8.16.3 
Test Script: 
Test Applet: 
Load Script: 
Clean-up Script: 

6.2.8.16.3 



Test Suite files 

API_2_PRH_FACYB_BS_1 .scr 
API_2_PRH_FACYB_BS_1 .Java 
API_2_PRH_FAC YB_BS_1 .Idr 
API_2_PRH_FACYB_BS_1 .ck 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 15 

Text String TLV = OD 10 04 01 02 ... OF 








ProactiveResponseHandler . getTheHandler ( ) 








f IndAndCopyValue ( ) with a null dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

tag = ODh 

dstBuffer.length = 20 
dstOffset = 21 


ArraylndexOutOfBoundsExceptio 
n is thrown 




3 


dstOffset < 

dstBuffer.length = 20 
dstOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




4 


length > dstBuffer.length 

dstBuffer.length = 15 
dstOffset = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + length >dstBuffer.length 

dstBuffer.length = 20 


ArraylndexOutOfBoundsExceptio 
n is thrown 
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dstOffset = 5 






6 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








Select a TLV (tag 02h) 








findAndCopyValueO 

tag = 04h 


ToolkltException.UNAVAILABLE 
ELEMENT is thrown 






Call the getValueLengthO method 


ToolkltException.UNAVAILABLE 
ELEIVIENT is thrown. 




7 


Successful call 

tag = ODh 

dstBuffer. length = 17 

dstOffset = 


Result of fincJAndcopyValueO is 
17 




8 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




9 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

dstBuffer. length = 20 
dstOffset = 2 


Result of findAndcopyValueO is 
19 




10 


Compare buffer 

buffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 


Result is OOh 




11 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, with 2 Text String TLV 

OD 11 04 00 01 ... OF 
OD 02 04 41 








ProactiveResponseHandler.getTheHandlerQ 








Successful call 

tag = ODh 

dstBuffer. length = 17 

dstOffset = 


Result of findAndcopyValueO is 
17 




12 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




13 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








Successful call (with tag 8Dh) 

tag = 8Dh 

dstBuffer. length = 17 

dstOffset = 


Result of findAndcopyValueO is 
17 




14 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 
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6.2.8.16.4 



Test Coverage 



CRR number 


Test case number 


N1 


8, 10, 12 


N2 


6 


N3 


7, 9, 11 


N4 


13, 14 


P1 


1 


P2 


2, 3, 4, 5 


C1 


Does not apply for 

Proactive Response 

Handler 



6.2.8.17 Method findAndCopyValue(byte tag, byte occurence, short valueOffset, byte[] 
dstBuffer, short dstOffset, short dstLength) 



Test Area Reference API 2 PRH FACYBBS BSS 



6.2.8.17.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public short f indAndCopyValue (byte tag, 

byte occurence, 
short valueOffset, 
byte[l dstBuffer, 
short dstOffset, 
short dstLength) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 

ToolkitException 

Normal execution 

CRRN 1 : looks for the indicated occurrence of a TLV element from the beginning of a TLV list and copy its value 
into a destination buffer. 

CRRN2: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN3: if the method is successful then the corresponding TLV becomes current and dstOffset + dstLength is 
returned. 

CRRN4: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if dstBuffer is null NullPointerException shall be thrown. 

CRRP2: if dstOffset or dstLength or both would cause access outside array bounds, or if dstLength is negative 
ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, dstLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

6.2.8.17.3 Test Suite files 

Test Script: API_2_PRH_FACYBBS_BSS_l.scr 
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Test Applet: 
Load Script: 
Clean-up Script: 

6.2.8.17.3 



API_2_PRH_FACYBBS_BSS_1 .Java 
API_2_PRH_FACYBBS_BSS_1 .Idr 
API 2 PRH FACYBBS BSS l.clr 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 15 

Text String TLV = OD 10 04 01 02 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








findAndCopyValueQ with a null dstBuffer 


NullPointerException is thrown 




2 


dstOffset > dstBuffer.length 

tag = ODh, occurrence = 1 
valueOffset = 
dstBuffer.length = 5 
dstOffset = 6 
dstLength = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


dstOffset < 

dstBuffer.length = 5 
dstOffset = -1 
dstLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


dstLength > dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 
dstLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


dstOffset + dstLength > dstBuffer.length 

dstBuffer.length = 5 
dstOffset = 3 
dstLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


dstLength < 

dstBuffer.length = 5 
dstOffset = 
dstLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 5 

Text String TLV = OD 06 04 01 02 ... 05 








ProactiveResponseHandler.getTheHandlerO 








valueOffset > Text String Length 

tag = ODh, occurrence = 1 
valueOffset = 7 
dstBuffer.length = 15 
dstOffset = 
dstLength = 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
dstBuffer.length = 15 
dstOffset = 
dstLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


dstLength > Text String length 

valueOffset = 
dstBuffer.length = 15 
dstOffset = 
dstLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + dstLength > Text String length 

valueOffset = 2 
dstBuffer.length = 15 
dstOffset = 
dstLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








Select a TLV (tag 02h) 
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findAndCopyValueO 

tag = ODh 
occurrence = 2 


ToolkltException.UNAVAILABLE 
_ELEMENT is thrown 






Call the getValueLengthO method 


ToolkltException.UNAVAILABLE 
ELEIVIENT is thrown. 




12 


Successful call 

tag = ODh, occurrence = 1 
valueOffset = 
dstBuffer. length = 17 
dstOffset = 
dstLength = 17 


Result of findAndCopyValueO is 
17 




13 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




14 


initialise dstBuffer 

dstBuffer = 55 55 ... 55 








Successful call 

tag = ODh, occurrence = 1 
valueOffset = 2 
dstBuffer. length = 20 
dstOffset = 3 
dstLength = 12 


Result of findAndCopyValueO is 
15 




15 


Compare buffer 

buffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 


Result is OOh 




16 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, with 2 Text String TLV 

OD 11 04 00 01 02 ... OF 

OD 06 00 11 22 33 44 55 (no specific DCS 

byte) 








ProactiveResponseHandler.getTheHandlerQ 








Successful call 

tag = ODh, occurrence = 1 
valueOffset = 
dstBuffer .length = 17 
dstOffset = 
dstLength = 17 


Result of findAndCopyValueO is 
17 




17 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 




18 


Successful call 

tag = ODh, occurrence = 2 
valueOffset = 
dstBuffer . length = 6 
dstOffset = 
dstLength = 6 


Result of findAndCopyValueO is 
6 




19 


Compare buffer 

buffer = 00 11 22 33 44 55 


Result is OOh 




20 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








Successful call (with tag 8Dh) 

tag = 8Dh, occurrence = 1 
valueOffset = 
dstBuffer. length = 17 
dstOffset = 
dstLength = 17 


Result of findAndCopyValueO is 
17 




21 


Compare buffer 

buffer = 04 00 01 ... OF 


Result is OOh 
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6.2.8.17.4 



Test Coverage 



CRR number 


Test case number 


N1 


13, 15, 17, 19 


N2 


11 


N3 


12, 14, 16, 18 


N4 


20,21 


P1 


1 


P2 


2,3,4,5,6 


P3 


7,8,9, 10 


CI 


Does not apply for 

Proactive Response 

Handler 



6.2.8.18 Method findAndCompareValue(byte tag, byteQ compareBuffer, short 
compareOffset) 



Test Area Reference API_2_PRH_FACRB_BS 



6.2.8.18.1 



Conformance requirement 



The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag, 

byte[] compareBuffer, 
short compareOffset) 
throws Java . lang. NullPointerException, 

Java .lang . Array I ndexOut Of Bounds Except ion. 
Toolkit Except ion 

Normal execution 

Looks for the first occurrence of a TLV element from beginning of a TLV list and compare its value with a buffer: 

CRRNl: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN2: if the method is successful then the corresponding TLV becomes current. 

CRRN3: if identical returns 0. 

CRRN4: if the first miscomparing byte in simple TLV is less than that in compareBuffer returns -I. 

CRRN5: if the first miscomparing byte in simple TLV is greater than that in compareBuffer returns 1. 

CRRN6; The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset would cause access outside array bounds ArraylndexOutOfBoundsException shall be 
thrown. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitExceptionHANDLER_NOT_AVAILABLE. 

6.2.8.18.3 Test Suite files 

Test Script: API_2_PRH_FACRB_BS_Lscr 

Test Applet: API_2_PRH_FACRB_BS_l.java 
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Load Script: 
Clean-up Script: 

6.2.8.18.3 



API_2_PRH_FACRB_BS_1 .Idr 
API_2_PRH_FACRB_BS_1 .clr 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 15 

Text String TLV = OD 10 04 01 02 ... OF 








ProactiveResponseHandler.getTheHandlerO 








findAndCompareValueO with a null dstBuffer 


NullPointerException is thrown 




2 


compareOffset > compareBuffer.length 

tag = ODh 

compareBuffer.length = 20 
compareOffset = 21 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 20 
compareOffset = -1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


length > compareBuffer.length 

compareBuffer.length = 15 
compareOffset = 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + length > 

compareBuf f er . length 
compareBuffer.length = 20 
compareOffset = 5 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








Select a TLV (tag 02h) 








findAndCompareValueO 

tag = 04h 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown 






Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown. 




7 


Initialise compareBuffer 

compareBuf fer = 
04 00 01 ... OF 








Compare buffers 

tag = ODh 
compareOffset = 


Result is OOh 




8 


Verify current TLV 

getValueLength ( ) 


Result is 17 




9 


Initialise compareBuffer 

compareBuffer = 
04 00 01 ... 10 








Compare buffers with same parameters 


Result is -1 




10 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result Is +1 




11 


Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOffset = 2 


Result is OOh 




12 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, with 2 Text String TLV 

OD 11 04 00 01 ... OF 
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OD 06 00 11 22 33 44 55 








ProactiveResponseHandler.getThehHandlerO 








Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOf f set = 2 


Result is OOh 




13 


Initialise compareBuffer 

compareBuffer = 
55 55 04 01 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OE OF 55 








Compare buffers 

compareOf f set = 2 


Result Is -1 




14 


Initialise compareBuffer 

compareBuffer = 
55 55 04 00 01 
02 03 04 05 06 
07 08 09 OA OB 
OC OD OD 10 55 








Compare buffers 

compareOf f set = 2 


Result is +1 




15 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








Initialise compareBuffer 

CompareBuffer = 
04 00 01 ... OF 








Compare buffers (with tag 8Dh) 

tag = 8Dh 
compareOf f set = 


Result is OOh 





6.2.8.18.4 



Test Coverage 



CRR number 


Test case number 


N1 


6 


N2 


8 


N3 


7, 11, 12 


N4 


9,13 


N5 


10, 14 


N6 


15 


PI 


1 


P2 


2, 3, 4, 5 


CI 


Does not apply for 

Proactive Response 

Handler 



6.2.8.19 Method findAndCompareValue(byte tag, byte occurence, short valueOffset, 
byteQ compareBuffer, short compareOffset, short compareLength) 

Test Area Reference API_2_PRH_FACRBBS_BSS 

6.2.8.19.1 Conformance requirement 

The method with following header shall be compliant to its definition in the API. 

public byte f indAndCompareValue (byte tag. 
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byte occurence, 
short valueOffset, 
byte[] compareBuf f er, 
short compareOf f set, 
short compareLength) 
throws Java . lang.NullPointerException, 

Java . lang . Array I ndexOut Of Bounds Except ion. 
Toolkit Except ion 

Normal execution 

Looks for the indicated occurrence of a TLV element from the beginning of a TLV Hst and compare its value with a 
buffer: 

CRRNl: if no TLV element is found, the UNAVAILABLE_ELEMENT exception is thrown and the current TLV is 
no longer defined. 

CRRN2: if the method is successful then the corresponding TLV becomes current. 

CRRN3: if identical is returned. 

CRRN4: if the first miscomparing byte in simple TLV is less than that in compareBuffer -1 is returned. 

CRRN5: if the first miscomparing byte in simple TLV is greater than that in compareBuffer 1 is returned 

CRRN6: The search method is comprehension required flag independent. 

Parameter errors 

CRRPl: if compareBuffer is null NullPointerException shall be thrown. 

CRRP2: if compareOffset or compareLength or both would cause access outside array bounds, or if compareLength 
is negative ArraylndexOutOfBoundsException shall be thrown. 

CRRP3: if valueOffset, compareLength or both are out of the current TLV an instance of ToolkitException shall be 
thrown. The reason code shall be ToolkitException OUT_OF_TLV_BOUND ARIES. 

CRRP4: if an input parameter is not valid (e.g. occurence = 0) an instance of ToolkitException shall be thrown. The 
reason code shall be ToolkitException BAD_INPUT_PARAMETER. 

Context errors 

CRRCl: if the handler is busy an instance of ToolkitException shall be thrown. The reason code shall be 
ToolkitException HANDLER_NOT_AVAILABLE. 

6.2.8.19.3 Test Suite files 

Test Script: API_2_PRH_FACRBBS_BSS_Lscr 

Test Applet: API_2_PRH_FACRBBS_BSS_l.java 

Load Script: API_2_PRH_FACRBBS_BSS_Lldr 

Clean-up Script: API_2_PRH_FACRBBS_BSS_Lclr 
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6.2.8.19.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 15 

Text String TLV = OD 10 04 01 02 ... OF 








ProactiveResponseHandler.getlheHandierO 








findAndCompareValueQ with a null 
compareBuffer 


NullPointerException is thrown 




2 


compareOffset > compareBuffer.length 

tag = ODh, occurrence = 1 
valueOffset = 
compareBuffer.length = 5 
compareOffset = 6 
compareLength = 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




3 


compareOffset < 

compareBuffer.length = 5 
compareOffset = -1 
compareLength = 1 


ArraylndexOutOfBoundsExceptio 
n is tlirown 




4 


compareLength >compareBuffer.length 

compareBuffer.length = 5 
compareOffset = 
compareLength = 6 


ArraylndexOutOfBoundsExceptio 
n is thrown 




5 


compareOffset + compareLength 

>compareBuf f er . length 
compareBuffer.length = 5 
compareOffset = 3 
compareLength = 3 


ArraylndexOutOfBoundsExceptio 
n is thrown 




6 


compareLength < 

compareBuffer.length = 5 
compareOffset = 
compareLength = -1 


ArraylndexOutOfBoundsExceptio 
n is thrown 




7 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 5 

Text String TLV = OD 06 04 01 02 ... 05 








ProactiveResponseHandler.getTheHandlerQ 








valueOffset > Text String Length 

tag = ODh, occurrence = 1 
valueOffset = 7 
compareBuffer.length = 15 
compareOffset = 
compareLength = 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




8 


valueOffset < 

valueOffset = -1 
compareBuffer.length = 15 
compareOffset = 
compareLength = 1 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




9 


compareLength > Text String length 

valueOffset = 
compareBuffer.length = 15 
compareOffset = 
compareLength = 7 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




10 


valueOffset + compareLength > Text String 
length 

valueOffset = 2 
compareBuffer.length = 15 
compareOffset = 
compareLength = 5 


ToolkitException.OUT OF TLV 
BOUNDARIES is thrown 




11 


Invalid parameter 

occurrence = 


ToolkitException.BAD INPUT P 
ARAMETER is thrown 




12 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








Select a TLV (tag 02h) 
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findAndCompareValueQ 

tag = ODh 
occurrence = 2 


ToolkitException.UNAVAILABLE 
_ELEMENT is thrown 






Call the getValueLengthO method 


ToolkitException.UNAVAILABLE 
ELEIVIENT is thrown. 




13 


Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








findAndCompareValueQ 

tag = ODh, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 17 


Result is OOh 




14 


Verify current TLV 

getValueLength ( ) 


Result is 17 




15 


Initialise compareBuffer 

compareBuffer = 
04 00 01 ... 10 








Compare buffers with same parameters 


Result is -1 




16 


Initialise compareBuffer 

compareBuffer = 
03 00 01 ... OF 








Compare buffers with same parameters 


Result is +1 




17 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers 

valueOffset = 2 
compareOf f set = 3 
compareLength = 12 


Result is OOh 




18 


Initialise compareBuffer 

compareBuffer = 
55 55 55 02 01 
03 04 05 06 07 
08 09 OA OB OC 
55 55 55 55 55 








Compare buffers with same parameters 


Result is -1 




19 


Initialise compareBuffer 

compareBuffer = 
55 55 55 01 02 
03 04 05 06 07 
08 09 OA OA OD 
55 55 55 55 55 








Compare buffers with same parameters 


Result is +1 




20 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, with 2 Text String TLV 

GO 11 04 00 01 ... OF 

OD 06 00 11 22 33 44 55 








ProactiveResponseHandler.getTheHandlerQ 








Initialise compareBuffer 

compareBuffer = 
04 00 01 ... OF 








findAndCompareValueQ 

tag = ODh, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 17 


Result is OOh 




21 


Initialise compareBuffer 

compareBuffer = 
00 11 22 33 44 55 








findAndCompareValueQ 


Result is OOh 
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tag = ODh, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 6 






22 


Initialise compareBuffer 

compareBuf fer = 
00 11 22 33 44 66 








findAndCompareValueQ 

tag = ODh, occurrence = 2 
valueOffset = 
compareOf f set = 
compareLength = 6 


Result is -1 




23 


Send a GET INPUT command 




GET INPUT Proactive 
command 




Terminal Response, Text String length = 16 

Text String TLV = OD 11 04 00 01 ... OF 








ProactiveResponseHandler.getTheHandlerQ 








Initialise compareBuffer 

CompareBuffer = 
04 00 01 ... OF 








Compare buffers (with tag 8Dh) 

tag = 8Dh, occurrence = 1 
valueOffset = 
compareOf f set = 
compareLength = 17 


Result is OOh 





6.2.8.19.4 



Test Coverage 



CRR number 


Test case number 


N1 


12 


N2 


14 


N3 


13, 17,20,21 


N4 


15, 18,22 


N5 


16, 19 


N6 


23 


P1 


1 


P2 


2, 3, 4, 5, 6 


P3 


7,8,9, 10 


P4 


11 


CI 


Does not apply for 

Proactive Response 

Handler 



6.2.9 Class ToolkitRegistry 
6.2.9.1 Method allocateTimer 

Test Area Reference: API_2_TKR_ATIM 

6.2.9.1.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public byte allocateTimer ( ) throws ToolkitException 

Normal execution 

CRRNl: the returned timer identifier shall be between 01 and 08 inclusive. 

CRRN2: the returned timer identifier shall be different from a previously allocated but not released one. 
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CRRN3: The SIM Toolkit Framework shall trigger the applet when receiving an ENVELOPE(TIMER 
EXPIRATION) command for the allocated timer. 

CRRN4: A call to isEventSet() method for EVENT_TIMER_EXPIRATION should return true if the applet has at 
least one timer allocated. 

Parameters error 

No requirements 

Context errors 

CRRCl: Shall throw a ToolkitException with reason NO_TIMER_A VAIL ABLE if all the timers are allocated. 

CRRC2: Shall throw a ToolkitException with reason NO_TIMER_AVAILABLE if the maximum number of 
timers have been allocated to this applet according to installation parameter. 

6.2.9.1.2 Test suite files 

Test Script: API_2_TKR_ATIM_l.scr 

Test Applet: 1 . API_2_TKR_ATIM_1 .Java 

2. API_2_TKR_ATIM_2.java 

3. API_2_TKR_ATIM_3.java 
Installation parameters: 

For this test procedure the non-volatile memory of each instance is 200 (Hexa). 
The maximum timer parameter value is as follows for each applet: 

- applet 1 (API_2_TKR_ATIM_1): 8 timers 

- applet 2 (API_2_TKR_ATIM_2): 4 timers 

- applet 3 (API_2_TKR_ATIM_3): timer 

Load Script: API_2_TKR_ATIM_l.ldr 

The load script installs the 6 instances. 
Cleanup Script: API_2_TKR_ATIM_l.clr 
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6.2.9.1.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Allocates up to 8 timers 
(applet 1) 

8 * allocateTimer ( ) . 


No exception shall be thrown. 

Timer ID returned shall be between 

01 and 08 inclusive. It shall be 

different after each call. 




2 


Allocate timers more than the maximum 
(applet 1) 

The applet 1 allocates 1 more timer. 


Shall throw a ToolkitException with 
reason NO_TIMER_AVAILABLE. 




3 


Check applet is Triggered by 

ENVELOPE(TIMER EXPIRATION) command 

(appletl) 

Send ENVELOPE (TIMER EXPIRATION) with all 
timers id (not in an increase order) . 

Calls releaseTimer (id) each time a timer 
expires . 


Shall trigger each time an 

ENVELOPE(TIMER EXPIRATION) 

is sent to the SIIVI, for Timer ID = 

'01 'to '08'. 




4 


Allocate up to 4 timers 
(applet 2) 

4 * allocateTimer . 


No exception shall be thrown. Each 
time, the returned timer identifier 

shall be between '01' and '08' 

inclusive. It shall be different after 

each call. 




5 


Allocate timers more than the maximum 
(applet 3) 

The applet 3 allocates 1 more timer. 


Shall throw a ToolkitException with 
reason NO_TIMER_AVAILABLE. 





6.2.9.1.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,4 


N2 


1,4 


N3 


3 


N4 


1 


CI 


2 


C2 


5 



6.2.9.2 Method changeMenuEntry 

Test Area Reference: API_2_TKR_CMETB_BSSBZBS 

6.2.9.2.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void changeMenuEntry (byte id, 

byte[] menuEntry, 
short offset, 
short length, 
byte nextAction, 
boolean helpSupported, 
byte iconQualif ier, 
short iconldentifier) 
throws Java . lang . NullPointerException, 

Java . lang . ArraylndexOutOf BoundsException, 
ToolkitException 
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Normal execution 

CRRNl: The SIM Toolkit Framework shall automatically update the menu stored in the ME by issuing a SET UP 
MENU proactive command. The later will reflect the changes done for the entry. The SIM Toolkit Framework 
shall use the data of the EF sume file in order to build the SET UP MENU command. 

CRRN2: The default state of the changed menu entry is 'enabled'. 

CRRN3: a call to isEventSet() method on EVENT_MENU_S ELECTION shall return true before and after the call. 

CRRN4: if helpSupported was true then a call to isEventSet() method on 
EVENT_MENU_SELECTION_HELP_REQUEST event shall return true. 

CRRN5: if helpSupported was true then after the completion of the SETUP MENU command, if an 

ENVELOPE(MENU_SELECTION_HELP_REQUEST) command is received by the SIM for this entry, then the 
SIM Toolkit framework shall trigger the applet. 

CRRN6: if help supported was true, the SIM Toolkit Framework shall issue a SETUP MENU command with 
command qualifier = '80' 

CRRN7: if helpSupported was false and if no entries is supporting help then a call to isEventSet() method on 
EVENT_MENU_SELECTION_HELP_REQUEST event shall return false . 

CRRN8: if helpSupported was false and if no entries is supporting help then after the completion of the SETUP 
MENU command, if an ENVELOPE(MENU_SELECTION_HELP_REQUEST) command is received by the 
SIM, then the SIM Toolkit framework shall not trigger the applet. 

CRRN9: The SIM Toolkit Framework shall supply in the SET UP MENU command with the icon identifier 

provided in the icon identifier list within the item icon identifier list Simple TLV if all the applets registered to 
the EVENT_MENU_SELECTION provide it. 

CRRNIO: The SIM Toolkit Framework shall set in the SET UP MENU command with the Icon list quaUfier 
transmitted to the ME as 'icon is not self explanatory' if one of the applet registered prefers this qualifier. 

CRRN 11 : If Next Action Indicator was different from '00', the SIM Toolkit Framework shall issue a SETUP 

MENU proactive command containing an Items Next Action Indicator simple TLV with the comprehension flag 
set to as defined in GSM 1 1.14 [4]. 

Parameters error 

CRRPl: Shall throwjava.lang.NullPointerException - if menuEntry is null 

CRRP2: Shall throw Java. lang.ArraylndexOutOfBoundsException - if offset would cause access outside array 
bounds 

CRRP3: Shall throw Java. lang.ArraylndexOutOfBoundsException - if length would cause access outside array 
bounds 

CRRP4:Shall throw java.lang.ArraylndexOutOfBoundsException - if both offset and length would cause access 
outside array bounds 

Context errors 

CRRCl: Shall throw a ToolkitException with MENU_ENTRY_NOT_FOUND reason if the Menu Identifier isn't 
associated to the calling applet instance. 

CRRC2: Shall throw ALLOWED_LENGTH_EXCEEDED if the menu entry string is bigger than the allocated 

space. 

6.2.9.2.2 Test suite files 

Additional requirements for the GSM personalisation: 

content of EF sume shall be: 

- Title Alpha Identifier: "TOOLKIT TEST" 
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Test Script: API_2_TKR_CMETB_BBSSBZBS_l.scr 

Test Applet: API_2_TKR_CMETB_BBSSBZBS_l.java 

- entry '01' is "Ink 1" 

- entry '02' is "Init2" 
Installation parameter: 

Same as default applet but with: 

Maximum text length for a menu entry: 15 

Maximum number of menu entries: 2 

Position / Identifier for each menu entry: '0r/'0r,'02'/'02' 

Load Script: API_2_TKR_CMETB_BBSSBZBS_l.ldr 

Cleanup Script: API_2_TKR_CMETB_BBSSBZBS_l.clr 
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6.2.9.2.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Applet changes the entry's title by menuEntry 

buffer, with a greater length than the initial 

length 

1- ChangeMenuEntry with parameters: 








Id = '02' 

MenuEntry = "UseAllBuf fer" 

Offset = 

Length = menuEntry . length 

NextAction = 

HelpSupported = false 

IconQualif ier = 

Iconldentif ier = 0. 


1- No exception shall be 
thrown. 

2- shall return true. 

3- shall return false. 






2- isEventSet (EVENT_MENU_SELECTION) . 

3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) . 




The SIM shall issue a 
SETUP MENU proactive 
command which contains 
the new text for entry ID 
'02'. 


2 


Changing the title with part of menuEntry 
buffer 

1- ChangeMenuEntry with parameters: 








Id = '01' 

MenuEntry = "UsePartOf Buf fer " 
Offset = 3 
Length = 12 
NextAction = 
HelpSupported = false 
IconQualif ier = 
Iconldentif ier = 0. 


1- No exception shall be 
thrown. 

2- Shall return true. 

3- Shall return false. 






2- IsEventSet (EVENT„MENU_SELECTION) . 

3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 




The SIM shall issue a 
SETUP MENU proactive 
command which contains 
the new text for entry ID 
'01'. 


3 


Length = 

1- ChangeMenuEntry for entry '01' and 
entry '02', with parameters: 








Id = '01'/'02' 
MenuEntry = "LengthEqualsO" 
Offset = 
Length = 
NextAction = 
HelpSupported = false 
IconQualif ier = 
Iconldentif ier = 0. 


1- No exception shall be 
thrown. 

2- Shall return true. 

3- shall return false. 






2- IsEventSet (EVENT_MENU_SELECTION) . 








3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) . 




The SIM shall issue a 
SETUP MENU proactive 
command which contains 
for entry '01 'and entry '02', 
no text part. 


4 


Setting a next action indicator != 








1- ChangeMenuEntry with parameters: 

Id = '02' 

MenuEntry = "NextActionlndic" 

Offset = 

Length = menuEntry . length 

NextAction = '10' (SETUP CALL) 

HelpSupported = false 


1- No exception shall be 
thrown. 

2- Shall return true. 

3- Shall return false. 


The SIM shall Issue a 
SETUP MENU proactive 
command which contains an 
Items Next Action Indicator 
list. 
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IconQualif ier = 








Iconldentif ier = 








2- isEventSet (EVENT_MENU_SELECTION) . 








3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 








EQUEST) . 






5 


Checking applet isn't triggered by a 








MENU_SELECTION_HELP_REQUEST 


Applet is not trigged by a 








MENU SELECTION HELP REQU 






Send ENVELOPE (MENU_SELECTION_HELP_REQUEST) 


EST 






with Item Identifier = '02' 






6 


help supported=true 

1- changeMenuEntry with parameters: 








Id = '02' 

MenuEntry = "HelpSupported" 


1- No exception shall be 






Offset = 


thrown. 






Length = menuEntry . length 








NextAction = 


2- Shall return true. 






HelpSupported = true 








IconQualif ier = 


3- Shall return true. 






Iconldentif ier = 








2- IsEventSet (EVENT_MENU_SELECTION) . 








3- 




The SIM shall issue a 




isEventSet (EVENT_MENU_SELECTION_HELP_R 




SETUP MENU proactive 




EQUEST) . 




command which contains a 
command qualifier '80'. 


7 


Checking applet is triggered by a 








MENU_SELECTION_HELP_REQUEST 


Applet is trigged by a 








MENU SELECTION HELP REOU 






Send ENVELOPE (MENU_SELECTION_HELP_REQUEST) 


EST 






with Item Identifier = ' 02 ' 






8 


Setting icons, help supported = false 

1- ChangeMenuEntry for entries 
' 01 ' , ' 02 ' , with parameters : 

Id = '01'/'02' 

MenuEntry = " IconQualif ier " 








Offset = 


1- No exception shall be 






Length = menuEntry . length 


thrown. 






NextAction = 








HelpSupported = false 


2- Shall return true. 






IconQualif ier = '01' 








Iconldentif ier = '02' / '01' 


3- Shall return false. 






2- IsEventSet (EVENT_MENU_SELECTION) . 








3- 




The SIM shall issue a 




isEventSet (EVENT_MENU_SELECTION_HELP_R 




SETUP MENU proactive 




EQUEST) . 




command which contains an 
Icon Identifier List. 


9 


MenuEntry is disabled 

1- disableMenuEntry ( ' 01 ' ) . 








2- changeMenuEntry with parameters: 


1- No exception shall be 
thrown. 






Id = '01' 








MenuEntry = "EnableEntry " 


2- No exception shall be 






Offset = 


thrown. 






Length = menuEntry . length 








NextAction = 








HelpSupported = false 


3- Shall return true. 






IconQualif ier = 




The SIM shall issue a 




Iconldentif ier = 


4- Shall return false. 


SETUP MENU proactive 




3- IsEventSet (EVENT_MENU_SELECTION) . 




command which contains 
the entry. Without Icon 




4- 




identifier List Simple TLV 
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isEventSet (EVENT_MENU_SELECTION_HELP_R 








EQUEST) . 






10 


MenuEntry is null 


Shall throw 






changeMenuEntry ( ) with : 
MenuEntry = NULL 


java.lang.NullPointerException. 




11 


Offset causes access outside array bounds 

Id = '01' 








MenuEntry = "Violation" 


Shall throw 






Offset = menuEntry . length +1 
Length = 


java.lang.ArraylndexOutOfBoundsE 






NextAction = 


xception. 






HelpSupported = false 








IconQualif ier = 








Iconldentif ier = 






12 


Big Offset causes access outside array bounds 

Id = '01' 








MenuEntry = "Violation" 


Shall throw 






Offset = 255 
Length = 1 


java.lang.ArraylndexOutOfBoundsE 






NextAction = 


xception. 






HelpSupported = false 








IconQualif ier = 








Iconldentif ier = 






13 


Offset < causes access outside array bounds 

Id = '01' 








MenuEntry = "Violation" 


Shall throw 






Offset = -1 
Length = 1 


java.lang.ArraylndexOutOfBoundsE 






NextAction = 


xception. 






HelpSupported = false 








IconQualif ier = 








Iconldentif ier = 






14 


Length causes access outside array bounds 

Id = '01' 








MenuEntry = "Violation" 


Shall throw 






Offset = 


java.lang.ArraylndexOutOfBoundsE 






Length = MenuEntry . length + 1 


xception. 






NextAction = 








HelpSupported = false 








IconQualif ier = 








Iconldentif ier = 0. 






15 


Length < causes access outside array 
bounds 

Id = '01' 








MenuEntry = "Violation" 


Shall throw 






Offset = 
Length = -1 
NextAction = 


java.lang.ArraylndexOutOfBoundsE 
xception. 






HelpSupported = false 








IconQualif ier = 








Iconldentif ier = 0. 






16 


Both offset and length causes access outside 
array bounds 








Id = '01' 


Shall throw 






MenuEntry = "Violation" 


java.lang.ArraylndexOutOfBoundsE 






Offset e [1, MenuEntry . length] 


xception. 






Length = MenuEntry . length 






NextAction = 1 








HelpSupported = false 








IconQualif ier = 








Iconldentif ier = 
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17 


Invalid ID used 

Id = '00' 

MenuEntry = contains text, != null 

Offset = 

Length = menuEntry . length < 16 

NextActlon = 

HelpSupported = false 

IconQuallf ler = 

Iconldentif ler = 


Shall throw a ToolkitException with 
MENU_ENTRY_NOT_FOUND 
reason code. 




18 


ID isn't allocated to a menu entry of this applet 
instance 

Id = 'OA' 

MenuEntry = contains text, != null 

Offset = 

Length = menuEntry . length < 16 

NextActlon = 

HelpSupported = false 

IconQuallf ler = 

Iconldentif ler = 


Shall throw a ToolkitException with 
reason code: 
MENU_ENTRY_NOT_FOUND. 




19 


The text is bigger than the allocated space 

Id = '02' 

MenuEntry = contains text, != null 

Offset = 

Length = menuEntry . length > 15 

NextActlon = 

HelpSupported = false 

IconQuallf ler = 

Iconldentif ler = 


Shall throw a ToolkitException with 
reason code: 
ALLOWED_LENGTH_EXCEEDED. 




20 


With a smaller text length than the initial length 

1. changeMenuEntry ( ) with parameters: 

Id = '02' 

MenuEntry = "Inlt" 
Offset = 

Length = menuEntry . length 
NextActlon = 
HelpSupported = false 
IconQuallf ler = 
Iconldentif ler = 

2 . IsEventSet (EVENT_MENU_SELECTION) 

3. 

IsEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 


1 . No exception shall be 
thrown. 

2. Shall return true. 

3. Shall return false. 


The SIM shall issue a 
SETUP MENU proactive 
command which contains 
the new text for entry ID 
'02'. 
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6.2.9.2.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3,4,6,8,9,20 


N2 


9 


N3 


1,2,3,4,6,8,9,20 






N4 


6 


N5 


7 


N6 


6 


N7 


1,2,3,4,8,9,20 


N8 


5 


N9 


8,9 


N10 


8 


Nil 


4 


P1 


10 


P2 


11,12,13 


P3 


14,15 


P4 


16 


C1 


17,18 


C2 


19 



6.2.9.3 Method clearEvent 

Test Area Reference: API_2_TKR_CEVTB 

6.2.9.3.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void clearEvent (byte event) 

throws ToolkitException 

Normal execution 

CRRNl: A call to isEventSet() method for a cleared event should return false after a call to clearEvent. 

CRRN2:The SIM Toolkit Framework shall not trigger the applet on the occurrence of the cleared event anymore. 

CRRN3: if event was EVENT_CALL_CONTROL_BY_SIM and after the call, no applet is registered to it, The SIM 
Toolkit Framework shall allow an applet to register to this event. 

CRRN4: if event was EVENT_CALL_CONTROL_BY_SIM and one applet is still registered to these event, The 
SIM Toolkit Framework shall not allow an applet to register to this event. 

CRRN5: if event was EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM and after the call, no applet is 
registered to it, The SIM Toolkit Framework shall allow an applet to register to this event. 

CRRN6: if event was EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM and one applet is still registered to 
these event, The SIM Toolkit Framework shall not allow an applet to set this event. 

Parameters error 

CRRPl: Shall throw a Toolkit Exception with reason EVENT_NOT_ALLOWED if event was 
EVENT_MENU_SELECTION. 

CRRP2: Shall throw a Toolkit Exception with reason EVENT_NOT_ALLOWED if event was 
EVENT_MENU_SELECTION_HELP_REQUEST. 

CRRP3: Shall throw a Toolkit Exception with reason EVENT_NOT_ALLOWED if event was 
EVENT_TIMER_EXPIRATION. 

CRRP4: Shall throw a Toolkit Exception with reason EVENT_NOT_ALLOWED if event was 
EVENT STATUS COMMAND. 
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Test suite files 

API_2_TKR_CEVTB_1 .scr 
API_2_TKR_ CEVTB _l.java 



As default but applet registers to an event list which contains all defined events in GSM 03.19 [7] excepted 
those that aren't allowed or supported by setEvent(). 



Load Script: 
Cleanup script: 

6.2.9.3.3 



API_2_TKR_ CEVTB_l.ldr 
API 2 TKR CEVTB l.clr 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Clear ALLOWED unregistered events 

For events ranging from 1 to 127 excepted 
those that aren't allowed 
(EVENT_MENU_SELECTION, 
EVENT_MENU_SELECTION_HELP_REQUEST, 
EVENT_TIMER_EXPIRATION, 
EVENT_STATUS_COI«AND) , 
the applet calls: 

1- clearEvent() method 

2- isEventSetO method 


1 - No exception is tlirown each 
time. 

2- Sliall return false each time. 




2 


Clear registered events 

1- For each ALLOWED and SUPPORTED events, 
the applet calls setEventO method. 

2- For events ranging from 1 to 127 
excepted those that aren't allowed, the 
applet calls ; 

2.1- clearEventO method 

2.2- isEventSetO method 


1- No exception shall be 
thrown. 

2.1- No exception shall be thrown. 

2.2- Shall return false. 




3 


Clearing NOT ALLOWED events 

For each event among: 

EVENT_MENU_SELECTION, 

EVENT_MENU_SELECTION_HELP_REQUEST, 

EVENT_TIMER_EXPIRATION, 

EVENT_STATUS_COMMAND 

1- The applet calls clearEvent (event ) 
method. 


1 - Each time, clearEvent shall 
throw a Toolkit Exception with 
reason EVENT_NOT_ALLOWED. 




4 


Checking applet isn't triggered by an 
ENVELOPE(SMS-PP DOWNLOAD) command 

1 - reset and initialise the card 

2 - An ENVELOPE (SMS-PP DOWNLOAD) is sent 
with a TAR referencing applet . 


Applet is not trigged by an 
ENVELOPE(SMS-PP 
DOWNLOAD) command 
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6.2.9.3.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2 


N2 


4 


N3 


Framework 


N4 


Framework 


N5 


Framework 


N6 


Framework 


P1 


3 


P2 


3 


P3 


3 


P4 


3 



6.2.9.4 Method disableMenuEntry 

Test Area Reference: API_2_TKR_DMETB 

6.2.9.4.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void disableMenuEntry (byte id) 
throws ToolkitException 

Normal execution 

CRRNl: A call to isEventSet() method on EVENT_MENU_SELECTION shall return the same result before and 
after the call to disableMenuEntryO method. 

CRRN2: A call to isEventSet() method on EVENT_MENU_SELECTION_HELP_REQUEST shall return the same 
result before and after the call to disableMenuEntryO method. 

CRRN3: After invocation of this method the SIM Toolkit Framework should dynamically update the menu stored 
in the ME . 

CRRN4: After invocation of this method, if there is no more enabled menu entries then the SIM Toolkit framework 
shall issue a SETUP MENU proactive command containing Item Data Object for Item 1 TLV with a length of 
zero and no value part. 

Parameters error 

No requirements 

Context errors 

CRRCl: shall throw a ToolkitException with reason = ENTRY_NOT_FOUND if the menu entry doesn't exist for 
this applet 

6.2.9.4.2 Test suite files 
Additional requirements for the GSM personalisation: 

content of EF sume shall be: 

- Tide Alpha Identifier: "TOOLKIT TEST" 
Test Script: API_2_TKR_DMETB_l.scr 

Test Applet: API_2_TKR_DMETB_l.java 

Installation parameter: 

Same as default applet but with: 
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- Maximum text length for a menu entry: 15 

- Maximum number of menu entries: 2 
Position / Identifier for each menu entry: 'Ol'/'Ol', '027'02' 

Load Script: API_2_TKR_DMETB_l.ldr 

Cleanup script: APl_2_TKR_DMETB_l.ch 



6.2.9.4.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Check the menu state before 

disabling a previously enabled entry 

not registered to 

EVENT_MENU_SELECTION_HELP_REQUEST 

1- reset and initialise the card 

2- isEventSet (EVENT_MENU_SELECTION) 
3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 


1- Shall return true 

2- Shall return false 


1- The SIM shall issue 
a SET UP MENU proactive 
command with entry '01' 
and '02'. 


2 


Check the menu state after 

disabling a previously enabled entry 

not registered to 

EVENT_MENU_SELECTION_HELP_REQUEST 

1- disableMenuEntry ( ' 01 ' ) 

2- IsEventSet (EVENT_MENU_SELECTION) 
3 — 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 


1- No exception shall be 
thrown. 

2- Shall return true. 

3- Shall return false. 


3- The SIM shall issue 
a SET UP MENU proactive 
command with entry '02' 
only. 


3 


Check the menu before 

disabling a previously enabled entry 

registered to 

EVENT_MENU_SELECTION_HELP_REQUEST 

1- change Menu Entry '02' to indicate 
help supported 

2- isEventSet (EVENT_MENU_SELECTION) 
3 — 

IsEventSet (EVENT_MENU_SELECTION_HELP__R 
EQUEST) 


2- Shall return true 

3- Shall return true 


3- The SIM shall issue 
a SET UP MENU proactive 
command with entry '02', 
indicating help supported. 


4 


Check the menu after 

disabling a previously enabled entry 

registered to 

EVENT_MENU_SELECTION_HELP_REQUEST 

1- disableMenuEntry ( '02' ) 

2- isEventSet (EVENT_MENU_SELECTION) 
3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 


1- No exception shall be 
thrown. 

2- Shall return true. 

3- Shall return true. 


3- The SIM shall issue 
a SET UP MENU proactive 
command with 1st Item TLV 
with a length of 0. 


5 


Disabling invalid entries 

For ID ranging from '00' to ' FF ' except 
'01' and '02', the applet calls 
disableMenuEntry (ID) method. 


Each time a Toolkit Exception with 
MENU_ENTRY_NOT_FOUND 
reason code shall be thrown. 
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6.2.9.4.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3,4 


N2 


1,2,3,4 


N3 


2,4 


N4 


4 


C1 


5 



6.2.9.5 Method enableMenuEntry 

Test Area Reference: API_2_TKR_EMETB 

6.2.9.5.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void enableMenuEntry (byte id) 
throws ToolkitException 

Normal execution 

CRRNl: A call to isEventSet() method on EVENT_MENU_SELECTION shall return the same result before and 
after the call to enableMenuEntryO method. 

CRRN2: A call to isEventSet() method on EVENT_MENU_SELECTION_HELP_REQUEST shall return the same 
result before and after the call to enableMenuEntryO method. 

CRRN3:The SIM Toolkit Framework should automatically issue a SETUP MENU proactive command which does 
contain an ITEM SIMPLE TLV object for this entry. 

Parameters error 

No requirements 

Context errors 

CRRCl: shall throw a ToolkitException with reason = MENU_ENTRY_NOT_FOUND if the menu entry doesn't 
exist for this applet 

6.2.9.5.2 Test suite files 
Additional requirements for the GSM personalisation: 

content of EF sume shall be: 

- Title Alpha Identifier: "TOOLKIT TEST" 

Test Script: API_2_TKR_EMETB_l.scr 

Test Applet: API_2_TKR_EMETB_l.java 

Installation parameter: 

Same as default applet but with: 

- Maximum text length for a menu entry: 15 
Maximum number of menu entries: 2 

Position / Identifier for each menu entry: 'Ol'/'Ol', '027'02' 
Load Script: API_2_TKR_EMETB_l.ldr 
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Cleanup script: API_2_TKR_EMETB_ 

.2.9.5.3 Test procedure 



l.clr 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Check menu state before 

enabling a previously disabled entry 

not registered to 

EVENT_MENU_SELECTION_HELP_REQUEST 

1- isEventSet (EVENT_MENU_SELECTION) 
2- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 
3- disableMenuEntry ( ' 01 ' ) 


1- Shall return true 

2- Shall return false 

3- No exception shall be 
thrown. 


3- The SIM shall issue 
a SET UP MENU proactive 
command with entry '02' 
only. 


2 


Check menu state after 

enabling a previously disabled entry 

not registered to 

EVENT_MENU_SELECTION_HELP_REQUEST 

1- enableMenuEntry ( ' 01 ' ) 

2- isEventSet (EVENT_MENU_SELECTION) 
3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 


1- No exception shall be 
thrown. 

2- Shall return true. 

3- Shall return false. 


3- The SIM shall issue 
a SET UP MENU proactive 
command with entry '01' 
and '02'. 


3 


Check menu state before 

enabling a previously enabled entry 

registered to 

EVENT_MENU_SELECTION_HELP_REQUEST 

1- change Menu Entry '02' to indicate 
help supported 

2- isEventSet (EVENT_MENU_SELECTION) 
3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 
4- disableMenuEntry (' 02 ' ) 


2- Shall return true 

3- Shall return true 

4- No exception shall be 
thrown 


4- The SIM shall issue 
a SET UP MENU proactive 
command with entry '01' 
indicating help supported. 


4 


Check menu state after 

enabling a previously enabled entry 

registered to 

EVENT_MENU_SELECTION_HELP_REQUEST 

1- enableMenuEntry (' 02 ') . 

2- isEventSet (EVENT_MENU_SELECTION) 
3- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 


1- No exception shall be 
thrown. 

2- Shall return true. 

3- Shall return true. 


3- The SIM shall issue 
a SET UP MENU proactive 
command with entries '01' 
and '02' indicating help 
supported. 


5 


Enabling invalid entries 

For ID ranging from '00' to ' FF ' except 
'01' and '02', the applet calls 
enableMenuEntry (ID) method. 


Each time a Toolkit Exception with 
MENU_ENTRY_NOT_FOUND 
reason code shall be thrown. 





6.2.9.5.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3,4 


N2 


1,2,3,4 


N3 


1,2,3,4 


CI 


5 
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6.2.9.6 Method getEntry 

Test Area Reference: API_2_TKR_GETY 

6.2.9.6.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public static ToolkitRegistry getEntry () 
throws ToolkitException 

Normal execution 

CRRNl: returns a reference to the applet ToolkitRegistry object of the calling applet. 

CRRN2: Each successive call to getEntryO method shall return the same object. 
Parameters error 

No requirements 
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6.2.9.6.2 
Test Script: 
Test Applet: 
Load Script: 
Cleanup script: 

6.2.9.6.3 



Test suite files 

API_2_TKR_GETY_1 .scr 
API_2_TKR_GETY_1 .Java 
API_2_TKR_GETY_1 .Idr 
API_2_TKR_GETY_1 .ck 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Installalation 

In the constructor, the applet instance 
calls the getEntryO method. 


Returns a not null ToolkitRegistry 
instance. 




2 


Check it returns the same entry 

The applet calls the getEntryO method 
again. 


Returns the same ToolkitRegistry 
instance as for test case 1 . 





6.2.9.6.4 



Test Coverage 



CRR number 


Test case number 


N1 


1 


N2 


2 



6.2.9.7 Method getPolllnterval 

Test Area Reference: API_2_TKR_GPOL 

6.2.9.7.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public short getPolllnterval ( ) 
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Normal execution 

CRRNl: shall return a value between 1 and 15300 if applet is registered to EVENT_STATUS_COMMAND event. 

CRRN2: shall return POLL_NO_DURATION value (0) if the toolkit applet is not registered to 
EVENT_STATUS_COMMAND event. 

Parameters error 

No requirements. 

Context errors 
No requirements. 

6.2.9.7.2 
Test Script: 
Test Applet: 
Load Script: 
Cleanup script: 

6.2.9.7.3 



Test suite files 

API_2_TKR_GPOL_l .scr 
API_2_TKR_ GPOL_l.java 
API_2_TKR_ GPOL_l .Idr 
API_2_TKR_ GPOL_l .clr 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Applet Isn't registered to 
EVENT_STATUS_COMMAND 

getPollInterval ( ) . 


Shall return 0. 




2 


Requesting max duration 

1- requestPollInterval (15300) 

2- Reset and initialize the card 

3- getPollInterval 


1- No exception shall be 
thrown. 

3- Shall return a value between 
1 and 15300. 




3 


Requesting System Duration 

1- 

requestPoll Interval (POLL_SYSTEM_DURATI 
ON) 

2- Reset and initialize the card 

3- getPollInterval . 


1- No exception shall be 

thrown. 

3- Shall return a value between 

1 and 15300. 




4 


Requesting no Duration 

1- requestPollInterval (POLL_NO_DURATION) 

2- Reset and initialize the card 

3- getPollInterval . 


1- No exception shall be 

thrown. 

3- Shall return 0. 
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6.2.9.7.4 Test Coverage 



CRR number 


Test case number 


N1 


2,3 


N2 


1,4 



6.2.9.8 Method initMenuEntry 

Test Area Reference: API_2_TKR_IMET_BSSBZBS 

6.2.9.8.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public byte initMenuEntry (byte [ ] menuEntry, 
short offset, 
short length, 
byte nextAction, 
boolean helpSupported, 
byte iconQualif ier, 
short iconldentif ier) 
throws Java. lang.NullPointerException, 

Java. lang. Array IndexOutOfBoundsExcept ion. 
Toolkit Except ion 

Normal execution 

CRRNl: The SIM Toolkit Framework shall automatically update the menu stored in the ME by issuing a SETUP 
MENU proactive command. The later will reflect the changes done for the entry. The SIM Toolkit Framework 
shall use the data of the EF sume file in order to build the SET UP MENU command. 

CRRN2: a call to isEventSet() method on EVENT_MENU_SELECTION shall return true after the l" successful 
call (without an exception). 

CRRN3: if helpSupported was true then a following call to isEventSet() method on 
EVENT_MENU_SELECTION_HELP_REQUEST event shall return true . 

CRRN4: if helpSupported was true then after the completion of the SETUP MENU command, if an 

ENVELOPE(MENU_SELECTION_HELP_REQUEST) command is received by the SIM for this entry, then the 
SIM Toolkit framework shall trigger the applet. 

CRRN5: if help supported was true, the SIM Toolkit Framework shall issue a SETUP MENU command with 
command qualifier = '80' 

CRRN6: if helpSupported was false and there isn't any menu entry supporting help then a call to isEventSet() 
method on EVENT_MENU_SELECTION_HELP_REQUEST event shall return false. 

CRRN7: The SIM Toolkit Framework shall supply in the SET UP MENU command with the icon identifier 

provided in the icon identifier list within the item icon identifier list Simple TLV if all the applets registered to 
the EVENT_MENU_SELECTION provide it. 

CRRN8: The SIM Toolkit Framework shall set in the SET UP MENU command with the Icon list qualifier 
transmitted to the ME as 'icon is not self explanatory' if one of the applet registered prefers this qualifier. 

CRRN9: If Next Action Indicator was different from '00', the SIM Toolkit Framework shall issue a SETUP 

MENU proactive command containing an Items Next Action Indicator simple TLV with the comprehension flag 
set to 0. 

CRRNIO: After the completion of the SETUP MENU command, if an ENVELOPE (MENU_SELECTION) 
command is received by the SIM for this identifier, then the SIM Toolkit framework shall trigger the applet. 

Parameters error 

CRRPl: Shall throw java.lang.NulIPointerException - if menuEntry is null 
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CRRP2: Shall throw Java. lang.ArraylndexOutOfBoundsException - if offset would cause access outside array 
bounds 

CRRP3: Shall throw Java. lang.ArraylndexOutOfBoundsException - if length would cause access outside array 
bounds 

CRRP4:Shall throw java.lang.ArraylndexOutOfBoundsException - if both offset and length would cause access 
outside array bounds 

Context errors 

CRRCl: Shall throw ALLOWED_LENGTH_EXCEEDED if the menu entry string is bigger than the allocated 
space 

CRRC2: Shall throw REGISTRY_ERROR if the menu entry cannot be initialised (eg no more item data in applet 
loading parameter) 

6.2.9.8.2 Test suite files 

Additional requirements for the GSM personalisation: 
content of EF sume shall be: 

- Title Alpha Identifier: "TOOLKIT TEST" 
Test case trigger: 1 - Applet instantiation 

2- Menu selection 

3- Menu selection Help Supported 
Test Script: API_2_TKR_IMET_BSSBZBS_l.scr 
Test Applet: API_2_TKR_IMET_BSSBZBS_l.java 

Installation parameter: 

Same as default applet but with: 

- Maximum text length for a menu entry: 15 

- Maximum number of menu entries: 6 

- Position / Identifier for each menu entry: 'Ol'/'Ol', '02702', '03'/'03', '04'/'04', '05'/'05', and '06'/'06' 
Load Script: API_2_TKR_IMET_BSSBZBS_Lldr 

Cleanup script: API_2_TKR_IMET_BSSBZBS_Lclr 
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6.2.9.8.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


NULL as parameter to menuEntry 

MenuEntry = NULL 


Shall throw a 
java.lang.NullPointerException. 




2 


Offset > menuEntry.length 

MenuEntry = "ToolkitTest " 
Offset = 12 
Length = 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




3 


Offset < 

MenuEntry = "ToolkitTest" 
Offset = -1 
Length = 11 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




4 


Offset = 255 

MenuEntry = "ToolkitTest" 
Offset = 255 
Length = 11 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




5 


Length = menuEntry.length+1 

MenuEntry = "ToolkitTest" 
Offset = 
Length = 12 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




6 


Length < 

MenuEntry = "ToolkitTest" 
Offset = 
Length = -1 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




7 


Offset + length > menuEntry.length 

MenuEntry = "ToolkitTest" 
Offset = 11 
Length = 1 


Shall throw 

java.lang.ArraylndexOutOfBoundsE 

xception. 




8 


MenuEntry.length > size allocated at loading 
for each menu entry 

MenuEntry = "ToolkitTest impossible" 
Offset = 
Length = 16 


ALLOWED_LENGTH_EXCEEDED 
ToolkitException is thrown. 




9 


Successful call, 
menuEntry is the whole buffer 

1- initMenuEntry ( ) 

MenuEntry = "TOOLKIT TEST 1" 
Offset = 
Length = 14 
NextAction = '00' 
HelpSupported = false 
IconQualif ier = '00' 
Iconldentif ier = 

2- isEventSet (EVENT_MENU_SELECTION) 


1- No exception shall be 
thrown, Shall return ID '01'. 

2- Shall return true. 




10 


Successful call, 
menuEntry part of a buffer 

1- initMenuEntry ( ) 

MenuEntry = " 1234567TOOLKIT TEST 2" 

Offset = 7 

Length = 14 

NextAction = '00' 

HelpSupported = false 

IconQualif ier = '00' 

Iconldentif ier = 

2- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 


1- No exception shall be 
thrown, Shall return ID '02'. 

2- Shall return false. 
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11 


Successful call, 
menuEntry with help supported 

1- initMenuEntry ( ) 

MenuEntry = "TOOLKIT TEST 3" 
Offset = 
Length = 14 
NextAction = '00' 
HelpSupported = true 
IconQualif ier = '00' 
Iconldentif ier = 

2- 

isEventSet (EVENT_MENU_SELECTION_HELP_R 
EQUEST) 


1- No exception shall be 
thrown, Shall return ID '03' 

2- Shall return true. 




12 


Successful call, 
menuEntry with an Icon 

MenuEntry = "TOOLKIT TEST 4" 

Offset = 

Length = 14 

NextAction = '00' 

HelpSupported = false 

IconQualif ier = '01' [icon not self 

explanatory] 

Iconldentif ier = 1 


1- No exception shall be 
thrown. 

2- Shall return ID '04' 




13 


Successful call, 
menuEntry with a next action indication 

MenuEntry = "TOOLKIT TEST 5" 

Offset = 

Length = 14 

NextAction = '24' [Select Item] 

HelpSupported = false 

IconQualif ier = '00' 

Iconldentif ier = 


1- No exception shall be 
thrown. 

2- Shall return ID '05' 




14 


Successful call, 
length = 

initMenuEntry ( ) 

MenuEntry = "ToolliitTest " 
Offset = 
Length = 
NextAction = '00' 
HelpSupported = false 
IconQualif ier = '00' 
Iconldentif ier = 


No exception shall be thrown, Shall 
return ID '06'. 




15 


Initialize more entry than allocated at loading 

MenuEntry = "ToolliitTest " 
Offset = 
Length = 11 


REGISTRY_ERROR 
ToolkitException is thrown. 




16 


Dynamic update of the menu stored by the me 

Fetch 




Card shall Send a 

SetUplVlenu Proactive 

command: 

[CommandOualifier]=help 

supported 

[Alphald]="TOOLKIT TEST" 

[ltemld=1] = "TOOLKIT 

TEST1" 

[ltemld=2] = "TOOLKIT 

TEST 2" 

[ltemld=3] = "TOOLKIT 

TEST 3" 

[ltemld=4] = "TOOLKIT 

TEST 4" 

[ltemld=5] = "TOOLKIT 

TEST 5" 

[ltemld=6] = "" 
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[ltemsNextAction]=0600000 
0002400 


17 


Check Applet is triggered by 
ENVELOPE(MENU_SELECTION) command 

Menu Entry ID = ' 01 ' 


Applet is trigged by an 
ENVELOPE(MENU_SELECTION) 
command & IVIenu Entry ID = '01' 




18 


Check Applet is triggered by 
ENVELOPE(MENU_SELECTION) command 

Menu Entry ID = ' 02 ' 


Applet is trigged by an 
ENVELOPE(MENU_SELECTION) 
command & IVIenu Entry ID = '02' 




19 


Check Applet is triggered by 
ENVELOPE(MENU_SELECTION) command 

Menu Entry ID = '03' 


Applet is trigged by an 
ENVELOPE(MENU_SELECTION) 
command & IVIenu Entry ID = '03' 




20 


Check Applet is triggered by 
ENVELOPE(MENU_SELECTION) command 

Menu Entry ID = ' 04 ' 


Applet is trigged by an 
ENVELOPE(MENU_SELECTION) 
command & IVIenu Entry ID = '04' 




21 


Check Applet is triggered by 
ENVELOPE(IVIENU_SELECTION) command 

Menu Entry ID = '05' 


Applet is trigged by an 
ENVELOPE(MENU_SELECTION) 
command & IVIenu Entry ID = '05' 




22 


Check Applet is triggered by ENVELOPE 
(MENU_SELECTION_HELP_REQUEST) 
command 

Menu Entry ID = '03' 


Applet is trigged by an 
ENVELOPE(MENU SELECTION 
HELP_REOUEST) command & 
IVIenu Entry ID = '03' 




23 


Check Applet is triggered by 
ENVELOPE(MENU_SELECTION) command 

Menu Entry ID = '06' 


Applet is trigged by an 
ENVELOPE(MENU_SELECTION) 
command & IVIenu Entry ID = '06' 





6.2.9.8.4 



Test Coverage 



CRR number 


Test case number 


N1 


16 


N2 


9 


N3 


11 


N4 


22 


N5 


11,16 


N6 


10 


N7 


12,16 


N8 


12,16 


N9 


13,16 


N10 


9,10,11,12,13,14,17,18,19,20,2 
1,23 


PI 


1 


P2 


2,3,4 


P3 


5,6 


P4 


7 


CI 


8 


C2 


14 
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6.2.9.9 Method isEventSet 

Test Area Reference: API_2_TKR_IEVSB 

6.2.9.9.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public boolean IsEventSet (byte event) 

Normal execution 

CRRNl: shall return true if the event is set in the Toolkit Registry for the applet 

CRRN2: shall return false if the event isn't set in the Toolkit Registry for the applet 
Parameters error 

No requirements. 

Context errors 
No requirements 

6.2.9.9.2 Test suite files 

Test Script: API_2_TKR_IEVSB_l.scr 

Test Applet: API_2_TKR_ lEVSB _1 .Java 

Installation parameter: 

Same as default applet but with: 

Maximum text length for a menu entry: 15 
Maximum number of menu entries: 1 

Position / Identifier for each menu entry: 'Ol'/'Ol' 
- Maximum number of timers: 1 

Load Script: API_2_TKR_ IEVSB_1 .Idr 

Cleanup script: API_2_TKR_ IEVSB_1 .clr 
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6.2.9.9.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Events aren't set 

Applet calls isEventSetO for each events 
ranging from 1 to 127 excepted 
EVENT_FORMATTED_SMS_PP_ENV and 
EVENT_MENU_SELECTION. 


Shall return false each time. 




2 


For EVENT_FORMATTED_SMS_PP_ENV 

isEventSet (EVENT_FORMATTED_SMS_PP_ENV) 


Shall return true. 




3 


For EVENT_MENU_SELECTION 

isEventSet (EVENT_MENU_SELECTION) 


Shall return true 




4 


After clearing 
EVENT_FORMATTED_SMS_PP_ENV 

1- clearEvent (EVENT_FORMATTED_SMS_PP_ENV) 

2- 

isEventSet (EVENT_FORMATTED_SMS_PP_ENV) 


1- No exception shall be 
thrown. 

2- Shall return false. 




5 


Setting events 

1- For each SUPPORTED and ALLOWED events 
for setEventO, applet calls: 

1.1- setEventO method 

1.2- isEventSet method. 


1.1- No exception shall be 
thrown. 

1 .2- Shall return true each time. 




6 


For 
EVENT_MENU_SELECTION_HELP_REQUEST 

1- IsEventSet 
(EVENT_MENU_SELECTION_HELP_REQUEST) 

2- call changeMenuEntry with help 
supported 

3- isEventSet 
(EVENT_MENU_SELECTION_HELP_REQUEST) 


1 - Shall return false. 
3- Shall return true 




7 


For EVENT_TIMER_EXPIRATION 

1- IsEventSet (EVENT_TIMER_EXPIRATION) 

2- call allocateTimer ( ) 

3- isEventSet (EVENT_TIMER_EXPIRATION) 


1- Shall return false. 
3- Shall return true 




8 


For EVENT_STATUS_COMMAND 

1- IsEventSet (EVENT_STATUS_COI«AND) 

2- call 

requestPollInterval (POLL_SYSTEM_DURATION) 

3- IsEventSet (EVENT_STATUS_COI«AND) 


1 - Shall return false. 
3- Shall return true 





6.2.9.9.4 



Test Coverage 



CRR number 


Test case number 


N1 


2,3,4,5,6,7,8 


N2 


1,5,6,7,8 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 243 ETSI TS 101 955 V7.1.0 (2001-06) 

6.2.9.10 Method releaseTimer 

Test Area Reference: API_2_TKR_RTIMB 

6.2.9.10.1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void releaseTimer {byte timerldentif ier) 
throws ToolkitException 

Normal execution 

CRRNl: if it was the last allocated timer for the applet then a following call to isEventSet() method for 
EVENT_TIMER_EXPIRATION should return false. 

CRRN2: if applet has timers allocated then a call to isEventSet(EVENT_TIMER_EXPIRATION) shall return true. 

CRRN3: After invocation of the method the indicated timer shall be released and available for reallocation. 

CRRN4: The applet is deregistered of the EVENT_TIMER_EXPIRATION for the indicated Timer Identifier. 

Parameters error 

CRRPl: shall throw a ToolkitException with INVALID_TIMER_ID reason if the timer identifier isn't between 1 
and 8. 

Context errors 

CRRCl: shall throw a ToolkitException with INVALID_TIMER_ID reason if the timer is valid but isn't allocated to 
this applet. 

6.2.9.10.2 Test suite files 

Test Script: API_2_TKR_RTIMB_l.scr 

Test Applet: API_2_TKR_RTIMB_l.java 

Installation parameter: 

As Default, except max timer which is set to 8. 
Load Script: API_2_TKR_RTIMB_l.ldr 

Cleanup script: API_2_TKR_RTIMB_l.clr 
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6.2.9.10.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Releasing not allocated timers 

For each timer ID ranging from '00' to 
'FF', applet calls releaseTimer (ID) . 


Each time, method shall throw a 
ToolkitException with reason code 
INVALID_TIMER_ID. 




2 


Releasing allocated timers 

1- 8 * allocateTimer . 

2- 7 * releaseTimer (id) . 

3- isEventSet (EVENT_TIMER_EXPIRATION) 


1- No exception shall be 
thrown. 

2- Each time, no exception shall be 
thrown. 

3- Shall return true 




3 


Releasing invalid timer ID 

1- releaseTimer ( 'FF ' ) method 

2- isEventSet (EVENT_TIMER_EXPIRATION) 


1- Shall throw a 
ToolkitException with 
INVALID_TIMER_ID reason code. 

2- Shall return true. 




4 


Releasing last timer 

1- releaseTimer (last timer allocated) 

2- IsEventSet (EVENT_TIMER_EXPIRATION) 


1- No exception shall be 
thrown. 

2- Shall return false. 




5 


Checking we can allocate timers after they 

have been released 
8 * allocateTimer . 


No exception shall be thrown. 




6 


Releasing all timers. 

For 1 to 8, releaseTimer (id) . 


No exception shall be thrown. 




7 


Checking applet isn't triggered by 

ENVELOPE (TIMER_EXPIRATION) command 
Send ENVELOPE (TIMER_EXPIRAT ION) 


Applet is not trigged by an 

ENVELOPE(TIMER_EXPIRATION) 

command 





6.2.9.10.4 



Test Coverage 



CRR number 


Test case number 


N1 


4 


N2 


2,3 


N3 


5,6 


N4 


7 


P1 


1,3 


C1 


Framework 



6.2.9.11 Method requestPolllnterval 

Test Area Reference: API_2_TKR_RPOLS 

6.2.9.1 1 .1 Conformance requirement: 

The method with following header shall be compliant to its definition in the API. 

public void requestPolllnterval (short duration) 
throws ToolkitException 
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Normal execution 

CRRNl: If duration is between 1 and 15300 or equal to POLL_SYSTEM_DURATION, the applet registers to 
EVENT_STATUS_COMMAND. 

CRRN2: If duration is POLL_NO_DURATION, the applet is deregistered from EVENT_STATUS_COMMAND. 

Parameters error 

CRRPl: the method should throw a ToolkitException with REGISTRY_ERROR reason if duration is > 15300 or is 
< -1 (P0LL_SYSTEM_DURAT10N). 

Context errors 

No Requirements. 

6.2.9.11.2 

Test Script: APl_2_TKR_RPOLS_l.scr 

Test Applet: APl_2_TKR_RPOLS_l.java 

Load Script: APl_2_TKR_RP0LS_l.ldr 

Cleanup script: API_2_TKR_RPOLS_l.clr 

6.2.9.11.3 



Test suite files 

API_2_TKR_RPOLS_ 
APl_2_TKR_RPOLS_ 
AP1_2_TKR_RP0LS_ 
API_2_TKR_RPOLS_ 

Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Requesting a value between 1 and 15300 s 

1- isEventSet (EVENT_STATUS_COMMMAND) 

2- For duration ranging from 1 to 15300, 
requestPollInterval (duration) . 

3- isEventSet (EVENT_STATUS_COMMAND) . 


1 - Shall return false. 

2- No exception shall be 
thrown. 

3- Shall return true. 




2 


1- Check Applet is triggered by a STATUS 
commandreset and card initialisation 

2- Send STATUS command 


2- Applet is trigged by a STATUS 
command 




3 


Requesting POLL SYSTEM DURATION 

1- isEventSet (EVENT_STATUS_COMMMAND) . 

2- 

RequestPollInterval (POLL_SYSTEM_DURATI 
ON) . 

3- IsEventSet (EVENT_STATUS_COMMAND) . 


1- Shall return true. 

2- No exception shall be 
thrown. 

3- Shall return true. 




4 


Check Applet is triggered by a STATUS 
command 

1- reset and card initialisation 

2- Send STATUS command 


2- Applet is trigged by a STATUS 
command 




5 


Requesting invalid duration 

For duration ranging from 15301 to 15305, 
-2 requestPollInterval (duration) 


Each time, a ToolkitException with 
REGISTRY_ERROR reason code, 
shall be thrown. 




6 


Requesting POLL NO DURATION 

1- IsEventSet (EVENT_STATUS_COMMMAND) 

2- requestPollInterval (POLL_NO_DURATION) 

3- isEventSet (EVENT_STATUS_COMMAND) 


1- Shall return true. 

2- No exception shall be 
thrown. 

3- Shall return false. 
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7 


Check Applet isn't triggered by an STATUS 
command. 

1- reset and card initialisation 

2- Send STATUS command 


2- Applet is not trigged by a 
STATUS command 





6.2.9.11.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2,3,4 


N2 


6,7 


P1 


5 



6.2.9.12 Method setEvent 

Test Area Reference: API_2_TKR_SEVTB 

6.2.9.12.1 Conformance Requirement: 

The method with following header shall be compliant to its definition in the API. 

public void setEvent (byte id) 

throws ToolkitException 

Normal execution 

CRRNl: a following call to isEventSet() method with the same event id shall answer true for the applet. 

CRRN2: the SIM Toolkit Framework shall trigger the applet if an occurrence of the set event happens. 

CRRN3: this method shall accept all the events defined in GSM 0319 excepted: EVENT_MENU_SELECTION, 
EVENT_MENU_SELECTION_HELP_REQUEST, EVENT_TIMER_EXPIRATION , 
EVENT_STATUS_COMMAND 

Parameters error 

CRRPl: shall throw a ToolkitException with EVENT_NOT_SUPPORTED reason if event is or event ranges from 
20 to 127. 

CRRP2: shall throw a ToolkitException with EVENT_NOT_ALLOWED reason if event is 
EVENT_MENU_SELECTION. 

CRRP3: shall throw a ToolkitException with EVENT_NOT_ALLOWED reason if event is 
EVENT_MENU_SELECTION_HELP_REQUEST. 

CRRP4: shall throw a ToolkitException with EVENT_NOT_ALLOWED reason if event is 
EVENT_TIMER_EXPIRATION. 

CRRP5: shall throw a ToolkitException with EVENT_NOT_ALLOWED reason if event is 
EVENT_STATUS_COMMAND. 

Context errors 

CRRCl: shall throw a ToolkitException with EVENT_ALREADY_REGISTERED if event is 
EVENT_CALL_CONTROL_BY_SIM but another applet is already registered to it. 

CRRC2: shall throw a ToolkitException with EVENT_ALREADY_REGISTERED if event is 

EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM but another applet is already registered to it. 

6.2.9.12.2 Test suite files 

Test Script: API_2_TKR_SEVTB_l.scr 
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Test Applet: 

Load Script: 

Cleanup script: 
6.2.9.12.3 



1 . API_2_TKR_SEVTB_1 .j ava 

2. API_2_TKR_SEVTB_2.java 
API_2_TKR_SEVTB_1 .Idr 

The load script installs the 2 instances. 
API_2_TKR_SEVTB_1 .clr 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Applet 1 is triggered by ENVELOPE(SMS 
PP_FORMATTED) command. 

Send ENVELOPE (SMS_PP_FORMATTED) 


Applet 1 shall be triggered 




2 


Setting ALLOWED and SUPPORTED events 

1- For all events defined in GSM 0319 
(from 1 to 19) and allowed: 
EVENT_PROF I LE_DOWNLOAD , 
EVENT_FORMATTED_SMS_PP_ENV, 
EVENT_FORMATTED_SMS_PP_UPD , 
EVENT_UNFORMATTED_SMS_PP_ENV, 
EVENT_UNFORMATTED_SMS_PP_UPD , 
EVENT_UNFORMATTED_SMS_CB , 
EVENT_CALL_CONTROL_B Y_S IM, 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM, 
EVENT_EVENT_DOWNLOAD_MT_CALL, 
EVENT_EVENT_DOWNLOAD_CALL_CONNECTED, 
EVENT_EVENT_DOWNLOAD_CALL_DISCONNECTED, 
EVENT_EVENT_DOWNLOAD_LOCATION_STATUS, 
EVENT_EVENT_DOWNLOAD_USER_ACTIVITY, 
EVENT_EVENT_DOWNLOAD_IDLE_SCREEN_AVAILABL 
E, 
EVENT_EVENT_DOWNLOAD_CARD_READER_STATUS 

1.1- clearEvent (event ) 

1.2- isEventSet (event) 

1.3- setEvent (event ) 

1.4- isEventSet (event) 

1.5- clearEvent (event ) 


1.1- No exception shall be thrown. 

1 .2- Shall return false. 

1 .3- No exception shall be thrown. 

1 .4- Shall return true. 

1 .5- No exception shall be thrown. 




3 


Event 

Call setEvent (0) 


Shall throw a ToolkltExceptlon with 
EVENT_NOT_SUPPORTED reason 
code. 




4 


Events from 20 to 127 

Call setEvent (event ) with event = 20 to 
127 


Shall throw a ToolkltExceptlon with 
EVENT_NOT_SUPPORTED reason 
code. 




5 


Setting EVENT_MENU_SELECTION 

Call setEvent (EVENT_MENU_SELECTION) 


Shall throw a ToolkltExceptlon with 
EVENT_NOT_ALLOWED reason 
code. 




6 


Setting 
EVENT_MENU_SELECTION_HELP_REQUEST 

Call 

setEvent (EVENT_MENU_SELECTION_HELP_REQUES 

T) 


Shall throw a ToolkltExceptlon with 
EVENT_NOT_ALLOWED reason 
code. 




7 


Setting EVENT_TIMER_EXPIRATION 


Shall throw a ToolkltExceptlon with 
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Call setEvent (EVENT_TIMER_EXPIRATION) 


EVENT_NOT_ALLOWED reason 
code. 




8 


Setting EVENT_STATUS_COIVIIVIAND 

Call setEvent (EVENT_STATUS_COMMAND) 


Shall throw a ToolkitException with 
EVENT_NOT_ALLOWED reason 
code. 




9 


Setting EVENT_CALL_CONTROL_BY_SIIVI 

Call setEvent (EVENT_CALL„CONTROL_BY_SIM) 


No Exception shall be thrown 




10 


Setting 

EVENT IMO SHORT {MESSAGE CONTROL B 

Y_SIIVI 

Call 

setEvent (EVENT_MO_SHORT_MESSAGE_CONTROL_B 

Y_SIM) 


No Exception shall be thrown 




11 


Check applet is triggered by an 
ENVELOPE(CALL_CONTROL_BY_SIM) 

Trigger the applet 


Applet is trigged by an 
ENVELOPE(CALL CONTROL BY 
SIM) 




12 


Check applet is triggered by an 

ENVELOPE(MO SHORT MESSAGE CONTRO 

L_BY_SIM) 

Trigger the Applet 


Applet is trigged by an 
ENVELOPE(MO SHORT MESSAG 
E_CONTROL_BY_SIM) 




13 


Applet 2 is triggered by ENVELOPE(SMS 
PP_DOWNLOAD) command. 

Trigger the applet 2 


Applet 2 is trigged by an 

ENVELOPE(SMS 

PR DOWNLOAD) command 




14 


Applet 2 registers to 
CALL_CONTROL_BY_SIM 
but it is already assigned 

setEvent (EVENT„CALL_CONTROL_BY_SIM) 


Shall throw a ToolkitException with 
EVENT_ALREADY_REGISTERED 
reason code. 




15 


Applet 2 registers to 

MO_MESSAGE_CONTROL_BY SIM 

but it is already assigned 

setEvent (EVENT_MO_SHORT_MESSAGE_CONTROL_B 
Y_SIM) 


Shall throw a ToolkitException with 
EVENT_ALREADY_REGISTERED 
reason code. 





6.2.9.12.4 



Test Coverage 



CRR number 


Test case number 


N1 


2 


N2 


1, 9,10,11, 12, 13 


N3 


2,5,6,7,8 


PI 


3,4 


P2 


5 


P3 


6 


P4 


7 


P5 


8 


CI 


14 


C2 


15 



6.2.9.13 Method setEventList 

Test Area Reference: API 2 TKR SEVL BSS 



6.2.9.13.1 



Conformance Requirement: 



The method with following header shall be compliant to its definition in the API. 

public void setEventList (byte [ ] eventList, 
short offset, 
short length) 
throws Java . lang . NullPointerException, 

Java .lang . ArraylndexOutOfBoundsException, 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 249 ETSI TS 101 955 V7.1.0 (2001-06) 

Toolkit Except ion 

Normal execution 

CRRNl: for all events set successfully by this method, a call to isEventSet() method should return true. 

CRRN2: the SIM Toolkit Framework shall trigger the applet if an occurrence of one of the successfully registered 
events happens. 

CRRN3: this method shall accept all the events defined in GSM 0319 excepted: EVENT_MENU_SELECTION, 
EVENT_MENU_SELECTION_HELP_REQUEST, EVENT_TIMER_EXPIRATION , 
EVENT_STATUS_COMMAND. 

Parameters error 

CRRPl: shall throw a java.lang.NullPointerException if eventList is null. 

CRRP2: shall throw a java.lang.ArraylndexOutOfBoundsException if offset would cause access outside array 
bounds. 

CRRP3: shall throw a java.lang.ArraylndexOutOfBoundsException if length would cause access outside array 
bounds. 

CRRP4: shall throw a java.lang.ArraylndexOutOfBoundsException if both offset and length would cause access 
outside array bounds. 

CRRP5: shall throw a ToolkitException with EVENT_NOT_SUPPORTED reason if event is or event ranges from 
20 to 127. 

CRRP6: shall throw a ToolkitException with EVENT_NOT_ALLOWED reason if eventList contains 
EVENT_MENU_SELECTION. 

CRRP7: shall throw a ToolkitException with EVENT_NOT_ALLOWED reason if eventList contains 
EVENT_MENU_SELECTION_HELP_REQUEST. 

CRRP8: shall throw a ToolkitException with EVENT_NOT_ALLOWED reason if eventList contains 
EVENT_TIMER_EXPIRATION. 

CRRP9: shall throw a ToolkitException with EVENT_NOT_ALLOWED reason if eventList contains 
EVENT_STATUS_COMMAND. 

Context errors 

CRRCl: shall throw a ToolkitException with EVENT_ALREADY_REGISTERED if eventList contains 
EVENT_CALL_CONTROL_BY_SIM but another applet is already registered to it. 

CRRC2: shall throw a ToolkitException with EVENT_ALREADY_REGISTERED if eventList contains 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM but another applet is already registered to it. 

6.2.9.13.2 Test suite files 

Test Script: API_2_TKR_SEVL_BSS_Lscr 

Test Applet: 1 . API_2_TKR_ SEVL_BSS _1 .Java 

2. API_2_TKR_ SEVL_BSS _2.java 
Load Script: API_2_TKR_ SEVL_BSS_1 .Idr 

The load script installs the 2 instances. 
Cleanup script: API_2_TKR_ SEVL_BSS_l.clr 
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6.2.9.13.3 



Test Procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Applet 1 Registering all eventList buffer 

EventList = all allowed events defined in 

GSM 0319: 

EVENT_P ROF I LE_DOWNLOAD , 

EVENT_FORMATTED_SMS_PP_ENV, 

EVENT_FORMATTED_SMS_PP_UPD, 

EVENT_UNFORMATTED_SMS_PP_ENV, 

EVENT_UNFORMATTED_SMS_PP_UPD, 

EVENT_UNFORMATTED_SMS_CB , 

EVENT_CALL_CONTROL_BY_SIM, 








EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM, 
EVENT_EVENT_DOWNLOAD_MT_CALL , 
EVENT_EVENT_DOWNLOAD_CALL_CONNECTED, 


1- No exception shall be 
thrown. 






EVENT_EVENT_DOWNLOAD_CALL_DISCONNECTED, 
EVENT_EVENT_DOWNLOAD_LOCATION_STATUS, 


2- No exception shall be 






EVENT_EVENT_DOWNLOAD_USER_ACTIVITY, 


thrown. 






EVENT_EVENT_DOWNLOAD_IDLE_SCREEN_AVAILABLE 








, EVENT_EVENT_DOWNLOAD_CARD„READER_STATUS 


3- Each time shall return true. 






1- For each event in EventList 
clearEvent (event) 


4- No exception shall be 
thrown. 






2- setEventList (eventList ) 








Offset = 








Length = eventList . lentgh 








3- For all events in eventList 








isEventSet (event) 








4- For each event in EventList 








clearEvent (event) 






2 


Registering part of eventList buffer 

EventList = all allowed events defined in 








GSM 0319 (see test case 1) . 


1- No exception shall be 






1- For each event in EventList 


thrown. 






clearEvent (event) 

2- setEventList (eventList , offset, 

length) 


2- No exception shall be 
thrown. 






Offset > 


3- Each time shall return true 






Length = eventList . lentgh - offset 


for events ranging from offset to 






3- For all events in eventList: 


offset+length else shall return false. 






isEventSet (event) 


4- No exception shall be 
thrown. 






4- For each event in EventList: 








clearEvent (event) 






3 


Null buffer 


Shall throw a 






EventList = null 


java.lang.NullPointerException 
Exception 




4 


Out of bounds offset 


Shall throw a 






Offset = eventList . length 
Length = 1 


java.lang.ArraylndexOutOfBounds 
Exception 




5 


Out of bounds and big offset 


Shall throw a 






Offset = 255 
Length = 1 


java.lang.ArraylndexOutOfBounds 
Exception 




6 


Offset < 


Shall throw a 






Offset = -1 


java.lang.ArraylndexOutOfBounds 
Exception 
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Length = 1 






7 


Out of bounds length 

Offset = 

Length = eventList . length + 1 


Shall throw a 

java.lang.ArraylndexOutOfBounds 

Exception 




8 


Out of bounds and big length 

Offset = 
Length = 255 


Shall throw a 

java.lang.ArraylndexOutOfBounds 

Exception 




9 


Length < 

Offset = 
Length = -1 


Shall throw a 

java.lang.ArraylndexOutOfBounds 

Exception 




10 


Out of bounds offset + Length 

Offset + length > eventList . length + 1 


Shall throw a 

java.lang.ArraylndexOutOfBounds 

Exception 




11 


Event 

Call setEventList (eventList ) with 
eventList indicating event 


Shall throw a ToolkitException with 
EVENT_NOT_SUPPORTED 
reason code. 




12 


Events from 20 to 127 

Call setEventList (eventList ) with 
eventList indicating all the events from 
20 to 127 


Shall throw a ToolkitException with 
EVENT_NOT_SUPPORTED 
reason code. 




13 


EVENT_MENU_SELECTION 

Call setEventList (eventList) with 
eventList indicating EVENT_MENU_SELECTION 


Shall throw a ToolkitException with 
reason code 
EVENT_NOT_ALLOWED. 




14 


EVENT_MENU_SELECTION_HELP_REQUEST 

Call setEventList (eventList) with 
eventList indicating 
EVENT_MENU_SELECTION_HELP_REQUEST 


Shall throw a ToolkitException with 
reason code 
EVENT_NOT_ALLOWED. 




15 


EVENT_TIMER_EXPIRATION 

Call setEventList (eventList) with 
eventList indicating 
EVENT_TIMER_EXPIRATION 


Shall throw a ToolkitException with 
reason code 
EVENT_NOT_ALLOWED. 




16 


EVENT_STATUS_COMMAND 

Call setEventList (eventList ) with 
eventList indicating EVENT_STATUS_COMMAND 


Shall throw a ToolkitException with 
reason code 
EVENT_NOT_ALLOWED. 




17 


Setting EVENT_CALL_CONTROL_BY_SIM 

setEventList (List, 0, 2) with List 
containing 

EVENT_CALL_CONTROL_BY_SIM S 
EVENT_MO_SHORT_MESSAGE_CONTROL_BY_SIM 


Shall not throw an exception 




18 


Check applet is triggered by an 
ENVELOPE(CALL_CONTROL_BY_SIM) 

Reset and initialise the card 
Trigger the applet 


Applet is trigged by an 
ENVELOPE{CALL CONTROL BY 
_SIM) 




19 


Check applet is triggered by an 

ENVELOPE(MO SHORT MESSAGE CONTROL 

_BY_SIM) 

Trigger the applet 


Applet is trigged by an 
ENVELOPE(MO SHORT MESSA 
GE_GONTROL_BY_SIM) 




20 


Applet 2 registers to CALL_CONTROL_BY_SIM 
but it is already assigned 

setEventList (MonoEventList , 0, 1) with 
MonoEventList containing 
EVENT_CALL_CONTROL_BY_SIM 


Shall throw a ToolkitException with 
EVENT_ALREADY_REGISTERED 
reason code. 
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21 


Applet 2 registers to 
MO SHORT MESSAGE CONTROL BY SIM 








but it is already assigned 


Shall throw a ToolkitException with 






setEventList(MonoEventList,0,1 ) with 


EVENT ALREADY REGISTERED 






MonoEventList containing 


reason code. 






EVENT MO SHORT MESSAGE CONTROL BY 








_SIM 







6.2.9.13.4 



Test Coverage 



CRR number 


Test case number 


N1 


1,2 


N2 


17,18,19 


N3 


1,2,11,12,13,14,15,16 


PI 


3 


P2 


4,5,6 


P3 


7,8,9 


P4 


10 


P5 


11,12 


P6 


13 


P7 


14 


P8 


15 


P9 


16 


CI 


20 


C2 


21 



6.2.10 Class ViewHandler 

It is not possible to test the methods provided by this class as it is declared 'abstract'; it will be done in the class 
inheriting it: EditHandler, EnvelopeHandler, ProactiveResponseHandler, ProactiveHandler. 

6.2.1 1 Class ToolkitException 
6.2.1 1 .1 Exception Constants 

Test Area Reference: API_2_TKE_CONS 

6.2.1 1 .1 .1 Conformance requirement: 
There is no API, only constants. 

Normal execution 

CRRNl: The Constants of the class ToolkitException shall all have the same name and value defined in the 
GSM03.19 . 

Parameters error 

No requirements 

Context errors 
No requirements 

6.2.11.1.2 Test suite files 

No additional requirements for the GSM personalisation 
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Test Script: 
Test Applet: 
Installation parameter: 
Load Script: 

Conversion parameter: 



API_2_TKE_CONS_l .scr 

API_2_TKE_CONS_l .Java 

API_2_TKE_CONS .install (Same as default applet) 

API_2_TKE_CONS .Idr 

At the end of the script the applet is loaded but not instantiated. 

API_2_TKE_CONS.cnv 



6.2.11.1.3 



Test procedure 



Id 


Description 


01 


Check constant HANDLER 0VERFL0W=1 


03 


Check constant UNAVAILABLE ELEMENT=3 


04 


Check constant MENU ENTRY NOT F0UND=4 


05 


Check constant REGISTRY ERR0R=5 


06 


Check constant EVENT NOT SUPP0RTED=6 


07 


Check constant EVENT ALREADY REGISTERED=7 


08 


Check constant OUT OF TLV B0UDARIES=8 


09 


Check constant ME PROFILE NOT AVAILABLE=9 


10 


Check constant ALLOWED LENGTH EXCEEDED=10 


11 


Check constant NO TIMER AVAILABLE=11 


12 


Check constant INVALID TIMER ID=12 


13 


Check constant EVENT NOT ALL0WED=13 


14 


Check constant BAD INPUT PARAMETER=14 



Test Coverage 



CRR number 


Test case number 


N1 


1-14 



6.2.11.1.4 



6.2.1 1 .2 Constructor ToolkitException 

Test Area Reference: API_2_TKE_COORS 

6.2.1 1 .2.1 Conformance requirement: 

The constructor with following headershall compliant to its definition in the API. 

public ToolkitException (short reason) 

Normal execution 

CRRNl: Construct a ToolkitException instance with the specified reason. 
Parameters error 

No requirements 

Context errors 
No requirements 

6.2.11.2.2 Test suite files 

No additional requirements for the GSM personalisation: 
Test Script: API_2_TKE _COORS_I .scr 

Test Applet: API_2_TKE _COORS_l .Java 

Load Script: API_2_TKE _COORS_I .Idr 
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Id 


Description 


API Expectation 


APDU Expectation 


1 


reason = (short) 19 


ToolkitException.getReasonO = 
(short) 19 





Test Coverage 



CRR number 


Test case number 


N1 


1 



6.2.11.2.4 



6.2.11.3 Method throwit 

Test Area Reference: API_2_TKE_THITS 

6.2.1 1 .3.1 Conformance requirement: 

The method with following header shall compliant to its definition in the API. 

public static void throwit (short reason) 
throws Toolkit Except ion 

Normal execution 

CRRNl: Throws the JCRE instance of the ToolkitException class with the specified reason. 

CRRN2: extends javacard.framework.CardRuntimeException 
Parameters error 

No requirements 

Context errors 
No requirements 

6.2.11.3.2 Test suite files 

No additional requirements for the GSM personalisation: 
Test Script: API_2_TKE_ THITS . scr 

Test Applet: API_2_TKE_ THITS .j ava 

Installation parameter: API_2_TKE_ THITS. install (Same as default applet) 

Load Script: API_2_TKE_ THITS.ldr 

Conversion parameter: API_2_TKE_ THITS. cnv 
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6.2.11.3.3 



Test procedure 



Id 


Description 


API Expectation 


APDU Expectation 


1 


Throws the JCRE instance of ToolkltException 
with the specified reason 


Reason (specified) 


can't be checl<ed because 
the status word's value is 
not specified 


2 


ToolkltException extends 
javacard.framework.CardRuntimeException 


Reason (specified) 





6.2.11.3.4 



Test Coverage 



CRR number 


Test case number 


N1 


1 


N2 


2 



6.3 



SIM Toolkit Framework 



Test Cases for the API and Framework have no interactions and are designed to be independant. The API Test Cases in 
the present specification shall be considered as completed although no framework tests have been agreed at the present 
time. 

System Handlers management 

minimum handler availability / status / content (+ response handling) 

Applet Triggering: 

for each event test separately: 

Registration / de registration, and dynamic registration 
- triggering 

multiple applet triggering 

limitations 

busy state 
Exception hiding to the mobile. 
Events combination. 
Proactive commands sending 
Envelope response sending 
Toolkit applets installation 
Access control 
File system state 



£75/ 



3GPP TS 11.13 version 7.1.0 Release 1998 



256 



ETSI TS 101 955 V7.1.0 (2001-06) 



Annex A (normative): 

Class and Methods AID numbering and acronyms 



A.1 Sim. access 



Class Name 


Acronyms 


Numbering on 5 bits 


SIMView 


svw 


00001 


SIMSystem 


SSY 


00010 


SIMViewException 


SVE 


00011 



A.1.1 SllVIView methods 



Method Name 


Acronyms 


Numbering on 6 bits 


static final Constants 




000001 


short increase {byte [ ] incr, short incrOffset, byte[] 
resp, short respOffset) 


INCR_BS_BS 


000010 


void invalidate 


INVL 


000011 


void readBinary (short fileOffset, byte[] resp, short 
respOffset, short respLength) 


REDBS_BSS 


000100 


short readRecord (short recNumber, byte mode, short 
recOffset, byte[] resp, short respOffset, short 
respLength) 


REDRSBS_BSS 


000101 


void rehabilitate ( ) 


REHA 


000110 


short seek (byte mode, byte[] patt, short pattOffset, 
short pattLength) 


SEEKB_BSS 


000111 


void select (short fid) 


SLOTS 


001000 


short select (short fid, byte[] fci, short fciOffset, 
short fciLength) 


SLCTS_BSS 


001001 


short status (byte [ ] fci, short fciOffset, short 
fciLength) 


STAT_BSS 


001010 


short updateBinary (short fileOffset, byte[] data, 
short dataOffset, short dataLength) 


UPDBS_BSS 


001011 


void updateRecord (short recNumber, byte mode, short 
recOffset, byte[] data, short dataOffset, short 
dataLength) 


UPDRSBS_BSS 


001100 



A.1 .2 SllVISystem methods 



Method Name 


Acronyms 


Numbering on 6 bits 


static SIMView getTheSIMView () 


GETS 


000001 



A.1. 3 SIMViewException methods 



Method Name 


Acronyms 


Numbering on 6 bits 


static void throwit (short reason) 


THITS 


000001 


SIMViewException (short reason) 


COORS 


000010 


Constants 


CONS 


000011 
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A.2 Sim.too kit 


Class Name 


Acronyms 


Numbering on 5 bits 


Toolkit Con St ants 


TKC 


00001 


Toolkitlnterface 


TKI 


00010 


EditHandler 


EDH 


00011 


EnvelopeHandler 


ENH 


00100 


EnvelopeResponseHandler 


ERH 


00101 


MEProfile 


MEP 


00110 


ProactiveHandler 


PAH 


00111 


ProactiveResponseHandler 


PRH 


01000 


ToolkitRegistry 


TKR 


01001 


ViewHandler 


VWH 


01010 


Toolkit Except ion 


TKE 


01011 



A.2.1 ToolkitConstants 



Method Name 


Acronyms 


Numbering on 6 bits 


Constants 


CONS 


000001 



A.2. 2 Toolkitlnterface methods 



Method Name 


Acronyms 


Numbering on 6 bits 


void processToolkit (byte event) 


PRTKB 


000001 



A.2.3 EditHandler methods 

The numbering of the EditHandler methods it will be done in the classes inherit it: EnvelopeResponseHandler, 
ProactiveHandler, because the methods provided by this class as it is declared 'abstract'. 



A.2. 4 EnvelopeHandler methods 



Method Name 


Acronyms 


Numbering on 6 bits 


byte getEnvelopeTag ( ) 


GENT 


000001 


byte get Itemldentif ier ( ) 


GIID 


000010 


short getSecuredDataLength ( ) 


GSDL 


000011 


short getSecuredDataOf f set ( ) 


GSDO 


000100 


EnvelopeHandler getTheHandler ( ) 


GTHD 


000101 


short getTPUDLOffset 


GTPO 


000110 








Inherited Method Name: ViewHandler 






Byte 

compareValue (short valueOff set, byte [ ] compareBuf fer, 

short compareOf f set , short compareLength) 


CPRVS_BSS 


0001 1 1 


Short 

copy (byte [] dstBuf fer, short dstOff set, short dstLengt 

h) 


GOPY_BSS 


001000 


Short 

copyValue (short valueOffset, 

byte[] dstBuf fer, short dstOff set, short dstLength) 


CPYVS_BSS 


001001 


Byte 
f indAndCompareValue (byte tag, byte [] compareBuf fer, sh 
ort compareOf f set ) 


FACRB_BS 


001010 


Byte f indAndCompareValue (byte tag, byte occurence, 
short valueOff set, byte [ ] compareBuf fer, short compare 
Offset, short compareLength) 


FAGRBBS_BSS 


001011 


Short 
FindAndCopyValue (byte tag, byte occurence, short value 


FAGYBBS_BSS 


001100 
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Offset, byte[] dstBuffer, short dstOffset, 
short dstLength) 






Short 
f indAndCopyValue (byte tag, byte [] dstBuffer, short dst 
Offset) 


FACYB_BS 


001101 


Byte 

FindTLV (byte tag, byte occurrence) 


FINDBB 


001110 


Short 
GetLengthO 


GLEN 


001111 


Byte 
GetValueByte (short valueOffset) 


GVBYTS 


010000 


Short 
GetValueLengthO 


GVLEN 


010001 



A.2.5 EnvelopeResponseHandler methods 



Method Name 


Acronym 


Numbering on 6 bits 


EnvelopeResponseHandler getTheHandler ( ) 


GTHD 


000001 


Void post (byte statusType) 


POSTS 


000010 


Void postAsBERTLV (byte statusType, byte tag) 


POSTBB 


000011 








Inherited Method Name: EditHandler 






Void appendArray (byte [ ] buffer, short offset, short 
length, short dstLength) 


APDA 


000100 


Void appendTLV (byte tag, byte value) 


APTLVBB 


000101 


Void appendTLV (byte tag, byte[] value, short 
valueOffset, short valueLength) 


APTLVB_BSS 


000110 


Void appendTLV (byte tag, byte valuel, byte value2) 


APTLVBBB 


000111 


Void appendTLV (byte tag, byte valuel, byte[] value2, 
short value20f f set, short value2Length) 


APTLVBB_BSS 


001000 


Void clear 


CLR 


001001 








Inherited Method Name: ViewHandler 






Byte 

compareValue (short valueOff set, byte [ ] compareBuf fer, 

short compareOf f set , short compareLength) 


GPRVS_BSS 


001010 


Short 

Copy (byte [] dstBuffer, short dstOffset, short dstLengt 

h) 


GOPY_BSS 


001011 


Short 

CopyValue (short valueOffset, 

byte[] dstBuffer, short dstOffset, short dstLength) 


GPYVS_BSS 


001100 


Byte 
FindAndCompareValue (byte tag, byte [] compareBuf fer, sh 
ort compareOf f set ) 


FACRB_BS 


001101 


Byte f indAndCompareValue (byte tag, byte occurence, 
short valueOff set, byte [ ] compareBuf fer, short compare 
Offset, short compareLength) 


FAGRBBS_BSS 


001110 


Short 
FindAndCopyValue (byte tag, byte occurence, short value 
Offset, byte[] dstBuffer, short dstOffset, 
short dstLength) 


FAGYBBS_BSS 


001111 


Short 
f IndAndCopyValue (byte tag, byte [] dstBuffer, short dst 
Offset) 


FACYB_BS 


010000 


Byte 

FindTLV (byte tag, byte occurrence) 


FINDBB 


010001 


Short 
GetLengthO 


GLEN 


010010 


Byte 
GetValueByte (short valueOffset) 


GVBYTS 


010011 


Short 
GetValueLengthO 


GVLEN 


010100 
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A.2.6 MEProfile methods 



Method Name 


Acronym 


Numbering on 6 bits 


static boolean check (byte index) 


CHECB 


000001 


Static boolean check (byte [] mask, short offset, short 
length) 


CHECBSS 


000010 



A.2.7 ProactiveHandler methods 



IVIethod Name 


Acronyms 


Numbering on 6 bits 


GetTheHandler 


GTHD 


000001 


Init (byte type, byte qualifier, byte dstDevice) 


INITBBB 


000010 


InitDisplayText (byte qualifier, byte dcs, byte[] 
buffer, short offset, short length) 


INDTBB_BSS 


000011 


InitGet Inkey (byte qualifier, byte dcs, byte[] buffer, 
short offset, short length) 


INGKBB_BSS 


000100 


InitGet Input (byte qualifier, byte dcs, byte[] buffer, 
short offset, short length, short minRespLength, 
short maxRespLength) 


INGPBB_BSSSS 


000101 


Byte sendO 


SEND 


000110 








Inherited Method Name: EditHandler 






Void appendArray (byte [ ] buffer, short offset, short 
length, short dstLength) 


APDA 


000111 


Void appendTLV (byte tag, byte value) 


APTLVBB 


001000 


Void appendTLV (byte tag, byte[] value, short 
valueOffset, short valueLength) 


APTLVB_BSS 


001001 


Void appendTLV (byte tag, byte valuel, byte value2) 


APTLVBBB 


001010 


Void appendTLV (byte tag, byte valuel, byte[] value2, 
short value20f f set , short value2Length) 


APTLVBB_BSS 


001011 


Void clear ( ) 


GLR 


001100 








Inherited Method Name: ViewHandler 






Byte 

CompareValue (short valueOffset, byte [ ] compareBuf fer, s 

hort compareOf f set, short compareLength) 


CPRVS_BSS 


001101 


Short 

Copy (byte [] dstBuf fer, short dstOff set, short dstLength 

) 


GOPY_BSS 


001110 


Short 

CopyValue (short valueOffset, 

byte[] dstBuf fer, short dstOff set, short dstLength) 


GPYVS_BSS 


001111 


Byte 
FindAndCompareValue (byte tag, byte [] compareBuf fer, sho 
rt compareOf f set ) 


FAGRB_BS 


010000 


Byte f indAndCompareValue (byte tag, byte occurence, 
short valueOffset, byte [ ] compareBuf fer, short compareO 
ffset, short compareLength) 


FAGRBBS_BSS 


010001 


Short 
FindAndCopyValue (byte tag, byte occurence, short valueO 
ffset, byte[] dstBuf fer, short dstOff set, 
short dstLength) 


FAGYBBS_BSS 


010010 


Short 
f indAndCopyValue (byte tag, byte [] dstBuf fer, short dstO 
ffset) 


FAGYB_BS 


010011 


Byte 

FindTLV (byte tag, byte occurrence) 


FINDBB 


010100 


Short 
GetLengthO 


GLEN 


010101 


Byte 
GetValueByte (short valueOffset) 


GVBYTS 


010110 


Short 
GetValueLengthO 


GVLEN 


010111 
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A.2.8 ProactiveResponseHandler methods 



Method Name 


Acronyms 


Numbering on 6 bits 


Short CopyAdditionallnformation (byte [ ] dstBuffer, 
short dstOffset, short dstLength) 


CPALBSS 


000001 


Short copyTextString (byte [] dstBuffer, short 
dstOffset) 


CPT_BS 


000010 


Short getAdditionalInf ormationLength ( ) 


GTIL 


000011 


Byte getGeneralResult ( ) 


GTGR 


000100 


Byte getltemldentif ier ( ) 


GTII 


000101 


Byte getTextStringCodingScheme ( ) 


GTCS 


000110 


Short getTextStringLength 


GTTL 


000111 


GetTheHandler 


GTHD 


001000 








Inherited Method Name: ViewHandler 






Byte 

CompareValue (short valueOff set, byte [ ] compareBuf fer, s 

hort compareOf f set , short compareLength) 


CPRVS_BSS 


001001 


Short 

Copy (byte [] dstBuffer, short dstOffset, short dstLength 

) 


COPY_BSS 


001010 


Short 

CopyValue (short valueOffset, 

byte[] dstBuffer, short dstOffset, short dstLength) 


CPYVS_BSS 


001011 


Byte 
FindAndCompareValue (byte tag, byte [] compareBuf fer, sho 
rt compareOf f set ) 


FACRB_BS 


001100 


Byte f indAndCompareValue (byte tag, byte occurence, 
short valueOff set, byte [ ] compareBuf fer, short compareO 
ff set, short compareLength) 


FACRBBS_BSS 


001101 


Short 
FindAndCopyValue (byte tag, byte occurence, short valueO 
ffset, byte[] dstBuffer, short dstOffset, 
short dstLength) 


FACYBBS_BSS 


001110 


Short 
f indAndCopyValue (byte tag, byte [] dstBuffer, short dstO 
ffset) 


FAGYB_BS 


001111 


Byte 

FindTLV(byte tag, byte occurrence) 


FINDBB 


010000 


Short 
GetLengthO 


GLEN 


010001 


Byte 
GetValueByte (short valueOffset) 


GVBYTS 


010010 


Short 
GetValueLengthO 


GVLEN 


010011 
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A.2.9 ToolkitRegistry methods 



Method Name 


Acronyms 


Numbering on 6 bits 


AllocateTimer () 


ATIM 


000001 


changeMenuEntry (byte id, byte [ ] menuEntry, short 
offset, short length, byte nextAction, boolean 
helpSupported, byte IconQualif ier, short 
iconldentif ier ) 


CMETB_BSSBZBS 


000010 


clearEvent (byte event) 


CEVTB 


000011 


disableMenuEntry (byte id) 


DMETB 


000100 


enableMenuEntry (byte id) 


EMETB 


000101 


getEntry () 


GETY 


000110 


getPollInterval () 


GPOL 


000111 


initMenuEntry (byte [ ] menuEntry, short offset, short 
length, byte nextAction, boolean helpSupported, byte 
iconQualif ier, short iconldentif ier) 


IMET_BSSBZBS 


001000 


isEventSet (byte event) 


lEVSB 


001001 


releaseTimer (byte timerldentif ier ) 


RTIM 


001010 


requestPollInterval (short duration) 


RPOL 


001011 


setEvent (byte event) 


SEVTB 


001100 


setEventList (byte [ ] eventList, short offset, short 
length) 


SEVL BSS 


001101 



A.2.10 ViewHandler methods 

The numbering of the ViewHandler methods it will be done in the classes inherit it: EditHandler, EnvelopeHandler, 
ProactiveResponseHandler, ProactiveHandler, because the methods provided by this class as it is declared 'abstract'. 

A.2.11 ToolkitException methods 



Method Name 


Acronyms 


Numbering on 6 bits 


static void throwit (short reason) 


THITS 


000001 


ToolkitException (short reason) 


GOORS 


000010 


Constants 


CONS 


00001 1 
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Annex B (normative): 

Script file syntax and format description 

CMD : Command to follow 

RST ; Resets and powers on the card 

OFF ; Powers off the card 

INI ; Performs the terminal profile with the following data. Afterwards, it shall perform all the 

fetch and terminal response commands until there is no proactive session in progress. 

REM ; Used for comments 

'\n'; Empty lines are accepted 

' ' , ' \t ' : Can be used as separator 

' \ ' : Continues on next line 

XXX : each line beginning with 3 characters indicates other tool command. 

[...] data to be checked, need to be present for an outgoing command. Bytes written as XX shall not be 
checked by the APDU tool. 

(...) status to be checked; when several status are valid they shall be separated by commas. Bytes 
written as XX shall not be checked by the APDU tool. 

REM this is an example 

RST 

INI FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF FF 

REM Case 1 example 

CMD AO C2 00 00 00 (91 33 , 69 XX) 

REM Case 2 example 
CMD AO C2 00 00 BO \ 

[XX XX XX 55 55 XX 55] (91 33 , 69 XX) 
CMD AO C2 00 00 BO [] (91 33 , 69 XX) 

CMD AO CO IF \ 

[10 AO 00 00 00 09 00 02 FF FF FF FF 89 28 A4 05 \ 
02 OD CC CC CC CC CC CC CC CC CC CC CC CC CC ] \ 
(90 00) 

REM Case 3 example 

CMD AO C2 00 00 33 \ 

Dl 31 82 02 83 81 06 05 80 11 22 33 44 8B 24 40 \ 

08 00 24 23 85 18 41 04 51 10 10 00 00 00 00 13 \ 

02 70 00 00 OE OD 00 00 00 00 28 A4 05 00 00 00 \ 

00 00 00 \ 

(90 00) 

OFF 

In order to show a common appearance all the scripts shall follow those format rules: 

- start always with a 'RST' followed by an 'INI' command. 

- The command, data to be checked and status to be checked shall be presented in the following order: 
CMD COMMAND [EXPECTED DATA] (EXPECTED STATUS) 

- APDU shall be presented with command (CLA INS PI P2 P3) in one line and data (if present) in next line 
grouped 16 bytes per line (see example above). 

- The expected data (if present) shall be presented in 16 bytes groups per line (see example above). 
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Annex C (normative): 
Default Prepersonalisation 

C.1 General Default Prepersonalisation 

This table shows the defauh prepersonalisation, the file system and the files' content, that the test SIM cards shall 
contain unless otherwise stated. 



Name 


Identifier 


Default Value 


Special Features 


EFicciD 


2FE2 


OF FF FF FF FF FF FF FF FF FF 


This value is not compliant with GSM 11.11 


EFiMsi 


6F07 


FF FF FF FF FF FF FF FF FF 


This value is not compliant with GSM 11.11 


EFlp 


6F05 


01 FF FF FF 




EFkc 


6F20 


FF FF FF FF FF FF FF FF 07 




EFpLMNsel 


6F30 


FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF FF FF FF FF FF FF FF FF 




EFhplmn 


6F31 


05 




EFACMmax 


6F37 


00 00 00 


Access condition UPDATE: CHV1 


EFssT 


6F38 


FF 3F C3 03 OC 00 FF OF 00 33 




EFacm 


6F39 


00 00 00 


Access condition UPDATE: CHV1 


EFpucT 


6F41 


FF FF FF 00 00 


Access condition UPDATE: CHV1 


EFbcch 


6F74 


FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF 




EFacc 


6F78 


00 00 




EFppLMN 


6F7B 


FF FF FF FF FF FF FF FF FF FF FF FF 




EFloci 


6F7E 


FF FF FF FF 00 FO 00 00 00 FF 01 




EFad 


6FAD 


00 FF FF 




EFphase 


6FAE 


03 




EFpDN 


6F3B 


Default value in all the records: 

FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF 


Records: 5 


EFsMSP 


6F42 


FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF FF FF 


Records: 1 


EFlnd 


6F44 


FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF 


Records: 1 


EFsMss 


6F43 


FF FF 




EFsMs 


6F3C 


1=' record: 00 FF ... FF (length 176) 
2"'* record: 00 FF ... FF (length 176) 
3"* record: 00 FF ... FF (length 176) 


Records: 3 


EFadn 


6F3A 


FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF 


Records: 1 


EFccp 


6F3D 


FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF 




EFmsisdn 


6F40 


FF FF FF FF FF FF FF FF FF FF FF FF 

FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF 


Records: 1 


EFsDN 


6F41 


FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF FF FF FF FF FF FF FF FF 
FF FF FF FF 


Records: 1 


EFsUME 


6F54 


85 OC 54 4F 4F 4C 4B 49 54 20 54 45 

53 54 FF FF FF FF 




EFcBMi 


6F45 


FF FF 




EFiM 


4F20 


FF FF FF FF FF FF FF FF FF FF FF 





The default value for the CHVl shall be "0x31 0x31 0x31 0x31 OxFF OxFF OxFF OxFF" and its state shall be 'disabled' 
during test applets execution. 
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C.2 Sim.Access.SimView test default prepersonalisation 
C.2.1 DFsiMTEST (SIM Test) 

Identifier: '0319' 

C.2. 2 EFtnr (Transparent Never Read) 



Identifier: '6F01' Structure: transparent 


IVIandatory 


File size: 3 bytes Update activity: low 


Access Conditions: 

READ NEVER 

UPDATE ALWAYS 

INVALIDATE ALWAYS 

REHABILITATE ALWAYS 


Bytes 


Description 


Default Value 


M/0 


Length 


1-3 


Test Data 


AA AA AA 


M 


3 bytes 



C.2. 3 EFjNu (Transparent Never Update) 



Identifier: '6F02' Structure: transparent 


IVIandatory 


File size: 3 bytes Update activity: low 


Access Conditions: 

READ ALWAYS 

UPDATE NEVER 

INVALIDATE ALWAYS 

REHABILITATE ALWAYS 


Bytes 


Description 


Default Value 


M/0 


Length 


1 -3 


Test Data 


55 55 55 


M 


3 bytes 



C.2. 4 EFtaru (Transparent Always Read and Update) 



Identifier: '6F03' Structure: transparent IVIandatory 


File size: 260 bytes Update activity: low 


Access Conditions: 
READ ALWAYS 
UPDATE ALWAYS 
INVALIDATE ALWAYS 
REHABILITATE ALWAYS 


Bytes 


Description 


Default Value 


M/0 


Length 


1 -260 


Test Data 


FF... FF 


M 


260 
bytes 
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C.2.5 EFcNR (Cyclic Never Read) 



Identifier: '6F04' Structure: cyclic 


Mandatory 


Record length: 3 bytes Update activity: high 


Access Conditions: 
READ NEVER 
UPDATE ALWAYS 
INCREASE ALWAYS 
INVALIDATE ALWAYS 
REHABILITATE ALWAYS 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data 


00 GO GO 


M 


3 bytes 


2 


Test Data 


00 GG GG 


M 


3 bytes 



C.2.6 EFcNu (Cyclic Never Update) 



Identifier: '6FG5' Structure: cyclic 


Mandatory 


Record length: 3 bytes Update activity: high 


Access Conditions: 

READ ALWAYS 

UPDATE NEVER 

INCREASE NEVER 

INVALIDATE ALWAYS 

REHABILITATE ALWAYS 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data 


00 GG GG 


M 


3 bytes 


3 


Test Data 


00 GG GG 


M 


3 bytes 



C.2.7 EFcNic (Cyclic Never Increase) 



Identifier: '6F06 Structure: cyclic 


Mandatory 


Record length: 3 bytes Update activity: high 


Access Conditions: 
READ ALWAYS 
UPDATE ALWAYS 
INCREASE NEVER 
INVALIDATE ALWAYS 
REHABILITATE ALWAYS 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data 


00 GG GG 


M 


3 bytes 


2 


Test Data 


00 GG GG 


M 


3 bytes 
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C.2.8 EFcNiv (Cyclic Never Invalidate) 



Identifier: '6F07 Structure: cyclic 


IVlandatory 


Record length: 3 bytes Update activity: high 


Access Conditions: 
READ ALWAYS 
UPDATE ALWAYS 
INCREASE ALWAYS 
INVALIDATE NEVER 
REHABILITATE ALWAYS 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data 


00 GO GO 


M 


3 bytes 


2 


Test Data 


00 GG GG 


M 


3 bytes 



C.2.9 EFcNRH (Cyclic Never Rehabilitate) 



Identifier: '6FG8' Structure: cyclic 


IVlandatory 


Record length: 3 bytes Update activity: high 


Access Conditions: 
READ ALWAYS 
UPDATE ALWAYS 
INCREASE ALWAYS 
INVALIDATE ALWAYS 
REHABILITATE NEVER 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data 


00 GG GG 


M 


3 bytes 


2 


Test Data 


00 GG GG 


M 


3 bytes 



C.2.10 EFcARu (Cyclic Always Read and Update) 



Identifier: '6FG9' Structure: cyclic 


Mandatory 


Record length: 3 bytes Update activity: high 


Access Conditions: 
READ ALWAYS 
UPDATE ALWAYS 
INCREASE ALWAYS 
INVALIDATE ALWAYS 
REHABILITATE ALWAYS 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data 


55 55 55 


M 


3 bytes 


2 


Test Data 


AA AA AA 


M 


3 bytes 
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C.2.1 1 EFlnr (Linear Fixed Never Read) 





Identifier: '6F0A' 


Structure: linear fixed IVIandatory 




Record length: 4 bytes 


Update activity: low 


Access Conditions: 

READ NEVER 

UPDATE ALWAYS 

INVALIDATE ALWAYS 

REHABILITATE ALWAYS 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data - Record 1 


FF FF FF FF 


M 


4 bytes 


2 


Test Data - Record 2 


FF FF FF FF 


M 


4 bytes 



C.2.1 2 EFlnu (Linear Fixed Never Update) 





Identifier: '6F0B' 


Structure: linear fixed Mandatory 




Record length: 4 bytes 


Update activity: low 


Access Conditions: 

READ ALWAYS 

UPDATE NEVER 

INVALIDATE ALWAYS 

REHABILITATE ALWAYS 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data - Record 1 


FFFFFFFF 


M 


4 bytes 


2 


Test Data - Record 2 


FF FF FF FF 


M 


4 bytes 



C.2.1 3 EFlaru (Linear Fixed Always Read and Update) 





Identifier: '6F0C' 


Structure: linear fixed Mandatory 


Record length: 4 bytes 


Update activity: low 




Acces 
READ 
UPDATE 
INVALIDATE 
REHABILITA 


s Conditions: 

ALWAYS 
ALWAYS 
ALWAYS 

TE ALWAYS 


Logical 
Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data - Record 1 


55 55 55 55 


M 


4 bytes 


2 


Test Data - Record 2 


AA AA AA AA 


M 


4 bytes 
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C.2. 1 4 EFciNA (Cyclic Increase Not Allowed) 



Identifier: '6F0D' Structure: cyclic IVlandatory 


Record length: 3 bytes Update activity: high 


Access Conditions: 
READ ALWAYS 
UPDATE ALWAYS 
INCREASE ALWAYS (see note 1 ) 
INVALIDATE ALWAYS 
REHABILITATE ALWAYS 


Logical Record 
Number 


Description 


Default Value 


M/0 


Length 


1 


Test Data 


00 00 00 


M 


3 bytes 


2 


Test Data 


00 00 00 


M 


3 bytes 


Note 1 : This file will be personalised in a way such that increase is not allowed, as indicated by the 
FCI byte 8, bit 7 (GSIV1 1 1 .11 : FCI structure of an EF returned by the SELECT command) 
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Annex D (normative): 

sim.test.util package and loading , testing and cleaning 

script examples. 

See attached files: 

Annex_D_SimTestUtil.zip 
Annex_D_Examples.zip 
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Annex E (normative): 
Test Area files. 

See attached file: 

Annex_E_TestAreaFiles_740.zip 
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Annex F (informative): 
Change history 



The table below indicates all changes that have been made to the present document since drafting work began. 



Change history | 


Date 


TSG# 


TSG Doc 


CR 


Rev 


Cat 


Subject/Comment 


Old 


New 


2000-10 


- 










Draft presented at T3#1 6 




0.2.0 


2000-12 


TP-10 


TP-000208 








Presented to TSG-T #10 for information 


0.2.0 


1.0.0 


2001-01 


- 


- 








Input to T3 #17 resulting from T3 ad hoc #24 


1.0.0 


1.1.0 


2001-03 


- 










Document presented for approval at T3#1 8 


1.1.0 


1.2.0 


2001-03 


TP-11 


TP-010041 








Doument presented for approval to TSG-T #1 1 (identical 
in technical content to v1 .2.0) 


1.2.0 


2.0.0 


2001-03 












As approved at TSG-T #1 1 (identical in technical content 
to V2.0.0) 


2.0.0 


7.0.0 


2001-05 












Correction to date on cover page / headers 


7.0.0 


7.0.1 
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TP-010105 


A001 




F 


Corrections to the API Test plan, addition of the test area 
files and modification of the util package 


7.0.1 
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